在 C# 和 ASP.NET MVC 中使用 ajax 从 SQL 服务器填充下拉列表
Populating dropdown from SQL Server with ajax in C# and ASP.NET MVC
调试器似乎根本没有进入成功功能。我试图填充的下拉菜单是 /Dokument/Dokument 路径中模态的一部分,当我按下按钮时,我得到了一个包含某些字段的模态。其中一个字段是一个下拉列表,它必须从 Tipi table 中获取值。在下拉菜单中,我什至没有看到消息
路由配置
namespace Archieve1
{
public class RouteConfig
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Login", id = UrlParameter.Optional }
);
}
}
}
AJAX 脚本
script type="text/javascript">
$(document).ready(function () {
$.ajax({
type: "GET",
url: "/NgarkoDokumentController/GetTipi",
data: "{}",
success: function (data) {
var s = '<option value="-1">Selektoni Tipin</option>';
for (var i = 0; i < data.length; i++) {
s += '<option value="' + data[i].Id_Tipi + '">' + data[i].Emri_llojit + '</option>';
}
$("#tipiDropdown").html(s);
}
});
});
</script>
控制器方法
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.UI.WebControls;
namespace Archieve1.Controllers
{
public class NgarkoDokumentController : Controller
{
public ActionResult Dokument()
{
return View();
}
// GET: NgarkoDokument
public ActionResult GetTipi()
{
Test_kristiEntities db = new Test_kristiEntities();
return Json(db.Tipi.Select(x => new
{
Id_Tipi = x.Id_Tipi,
Emri_llojit = x.Emri_llojit
}).ToList(), JsonRequestBehavior.AllowGet);
// return View();
}
}
}
我用一些 tables
构建的模型
namespace Archieve1.Models
{
public class NgarkoDokument
{
public Dokumenti Dokumenti { get; set; }
public Fusha_Indeksimit FushaIndeksimit { get; set; }
public Vendndodhja_Fizike Vendndodhja_fizike { get; set; }
public IEnumerable<Tipi> Tipi { get; set; }
}
}
这是 html
@model Archieve1.Models.NgarkoDokument
<select title="Lloji i dokumentit" name="lloji" class="form-control col-md-3 box" id="tipiDropdown"> </select>
ASP.NETMVC 5的默认路由{controller}/{action}/{id}
,/{id}
部分可选
{controller}
指的是您的 C# 控制器的 class 名称,但它删除了末尾的单词 Controller
。在您的示例中,控制器名称为 NgarkoDokument
.
{action}
指的是你的action的方法名。在您的示例中,GetTipi
.
所以路线变成/NgarkoDokument/GetTipi
。
相关文档如下:
调试器似乎根本没有进入成功功能。我试图填充的下拉菜单是 /Dokument/Dokument 路径中模态的一部分,当我按下按钮时,我得到了一个包含某些字段的模态。其中一个字段是一个下拉列表,它必须从 Tipi table 中获取值。在下拉菜单中,我什至没有看到消息
路由配置
namespace Archieve1
{
public class RouteConfig
{
public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
name: "Default",
url: "{controller}/{action}/{id}",
defaults: new { controller = "Home", action = "Login", id = UrlParameter.Optional }
);
}
}
}
AJAX 脚本
script type="text/javascript">
$(document).ready(function () {
$.ajax({
type: "GET",
url: "/NgarkoDokumentController/GetTipi",
data: "{}",
success: function (data) {
var s = '<option value="-1">Selektoni Tipin</option>';
for (var i = 0; i < data.length; i++) {
s += '<option value="' + data[i].Id_Tipi + '">' + data[i].Emri_llojit + '</option>';
}
$("#tipiDropdown").html(s);
}
});
});
</script>
控制器方法
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.UI.WebControls;
namespace Archieve1.Controllers
{
public class NgarkoDokumentController : Controller
{
public ActionResult Dokument()
{
return View();
}
// GET: NgarkoDokument
public ActionResult GetTipi()
{
Test_kristiEntities db = new Test_kristiEntities();
return Json(db.Tipi.Select(x => new
{
Id_Tipi = x.Id_Tipi,
Emri_llojit = x.Emri_llojit
}).ToList(), JsonRequestBehavior.AllowGet);
// return View();
}
}
}
我用一些 tables
构建的模型namespace Archieve1.Models
{
public class NgarkoDokument
{
public Dokumenti Dokumenti { get; set; }
public Fusha_Indeksimit FushaIndeksimit { get; set; }
public Vendndodhja_Fizike Vendndodhja_fizike { get; set; }
public IEnumerable<Tipi> Tipi { get; set; }
}
}
这是 html
@model Archieve1.Models.NgarkoDokument
<select title="Lloji i dokumentit" name="lloji" class="form-control col-md-3 box" id="tipiDropdown"> </select>
ASP.NETMVC 5的默认路由{controller}/{action}/{id}
,/{id}
部分可选
{controller}
指的是您的 C# 控制器的 class 名称,但它删除了末尾的单词 Controller
。在您的示例中,控制器名称为 NgarkoDokument
.
{action}
指的是你的action的方法名。在您的示例中,GetTipi
.
所以路线变成/NgarkoDokument/GetTipi
。
相关文档如下: