下拉列表选项未填充

Options Of dropdown are not populating

提问人:Sashank 提问时间:10/25/2023 最后编辑:Qing GuoSashank 更新时间:10/27/2023 访问量:38

问:

标题:使用 AJAX 的 ASP.NET Core 中的级联下拉列表问题(404 错误)

'描述:

我正在做一个项目,该项目需要使用 AJAX 在 ASP.NET Core 中实现级联下拉列表。目标是为“国家/地区”、“省/自治区/直辖市

我已经设置了控制器来处理 AJAX 请求,并使用必要的 HTML 和 JavaScript 配置了视图。但是,我在尝试使用 AJAX 获取州和城市时遇到了 404 错误。

Controller Code (Extract from LecturerController):-


        [HttpGet]
        [Route("Lecturers/GetStatesByCountry/{CountryID}")]
        public IActionResult GetStatesByCountry(int CountryID)
        {
            // Replace this with your logic to fetch states based on the countryID.
            List<State> states = dbAccessLayer.GetStatesByCountryID(CountryID);

            // Convert the list of states to a format that can be easily serialized to JSON.
            var stateList = states.Select(s => new { Key = s.StateID, Value = s.StateName });

            return Json(stateList);
        }


        [HttpGet]
        [Route("Lecturers/GetCitiesByState/{StateID}")]
        public JsonResult GetCitiesByState(int StateID)
        {
            List<StudentP.Models.City> cities = dbAccessLayer.GetCitiesByStateID(StateID);
            var cityList = cities.Select(c => new { Key = c.CityID, Value = c.CityName }).ToList();
            return Json(cityList);
        }

View Code:-

@model StudentP.Models.LecturersModel
@using Microsoft.AspNetCore.Mvc.Rendering

@{
    ViewData["Title"] = "Create";
}

@using (Html.BeginForm("Create", "Lecturers", FormMethod.Post))
{
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="utf-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Create Lecturer</title>
        <!-- Include Bootstrap CSS -->
        <link id="theme-link" rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.6.0/css/bootstrap.min.css" integrity="sha512-+w5jrxF5Tl2M9z6zweF98Cc5wPwP71A66f+OWiv60lgG1G9HjGjznfcLB8/aVvIs2hTfbj7z3VQgBEN8SP6KYg==" crossorigin="anonymous" />
        <!-- Include Font Awesome CSS for icons -->
        <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css" integrity="sha512-ApNbghDs4vEX71nKGjW1rBq2v3Qxss3q5Dx9juYbfc4z3P8h6blVpz3x8M8A2FpxsdzU+Uug7c3dDlPZZXnZ6Lw==" crossorigin="anonymous" />

        <!-- Your custom CSS styles -->
        <link rel="stylesheet" href="your-custom-styles.css" />

        <!-- Dark Mode Toggle Button -->
        <style>
            /* Define a custom dark mode class */
            body {
                transition: background-color 0.5s, color 0.5s;
                position: relative;
                background: linear-gradient(to bottom, #ccc, #333);
                color: #eee;
            }

            body.dark-mode {
                background: #333;
                color: #fff;
            }

            #dark-mode-toggle {
                position: fixed;
                bottom: 20px;
                right: 20px;
                z-index: 9999;
            }
        </style>
    </head>
    <body>
        <div class="container mt-5">
            <div class="row mb-3">
                <div class="col-md-12">
                    <a class="minimal-button" asp-action="Create">Create New</a>
                    <a class="minimal-button" href="javascript:history.back();">Back</a>
                </div>
            </div>

            <div class="row mb-3">
                <div class="col-md-12">
                    <h1>Create Lecturer</h1>
                </div>
            </div>

            <div class="row mb-3">
                <div class="col-md-4">
                    <form asp-action="Create">
                        <div asp-validation-summary="ModelOnly" class="text-danger"></div>
                        <div class="form-group">
                            <label asp-for="FirstName" class="control-label">First Name</label>
                            <input asp-for="FirstName" class="form-control" />
                            <span asp-validation-for="FirstName" class="text-danger"></span>
                        </div>
                        <div class="form-group">
                            <label asp-for="LastName" class= "control-label">Last Name</label>
                            <input asp-for="LastName" class="form-control" />
                            <span asp-validation-for="LastName" class="text-danger"></span>
                        </div>
                        <div class="form-group">
                            @Html.LabelFor(model => model.CountryID, "Country")
                            @Html.DropDownListFor(model => model.CountryID, ViewBag.Country as SelectList, "Select Country", new { @class = "form-control", id = "CountryID" })
                        </div>

                        <div class="form-group">
                            @Html.LabelFor(model => model.StateID, "State")
                            @Html.DropDownListFor(model => model.StateID, ViewBag.States as SelectList, "Select State", new { @class = "form-control", id = "StateID" })
                        </div>
                        <div class="form-group">
                            @Html.LabelFor(model => model.CityID, "City")
                            @Html.DropDownListFor(model => model.CityID, ViewBag.Cities as SelectList, "Select City", new { @class = "form-control", id = "CityID" })
                        </div>

                        <div class="form-group">
                            <button type="submit" class="btn btn-primary">Create</button>
                            <a class="btn btn-secondary btn-lg btn-block" href="javascript:history.back();">Back</a>
                        </div>
                    </form>
                </div>
            </div>

            <!-- Dark Mode Toggle Button -->
            <button id="dark-mode-toggle" class="btn btn-primary">Toggle Dark Mode</button>
        </div>
        <script src="https://code.jquery.com/jquery-3.6.0.min.js" integrity="sha512-d7I2WYT6F3RM1fD0dJ7b5AO0MvtA0bB9zTj16QKrq5KJDONBZg4z8lqrV5k3F/C6q0fs17IC3UZ5Yb4OgYms6tZw==" crossorigin="anonymous"></script>
        <script src="https://cdn.datatables.net/1.10.25/js/jquery.dataTables.min.js" integrity="sha512-6cXGp4d5PzR0eC+ZvApK1xID5Vy2XsXpB53dJPMTvIv/yzHzpk2Oi8gY4pF3x67bH7aGrb1a0ir8uG1mYcqr/Xw==" crossorigin="anonymous"></script>
        <script src="https://cdn.datatables.net/1.10.25/js/dataTables.bootstrap4.min.js" integrity="sha512-AGV1fOtuAX+IiWXaemgak5tuU0+hh5+dPCa6Z6FgsqEq/UJGn3+nIO91MVp2g69sMWHdF/VtTa9/i7s7Q9/66w==" crossorigin="anonymous"></script>
        <script src="https://cdn.jsdelivr.net/npm/sweetalert2@10"></script>

        @section scripts {
        <script>
            function updateStateDropdown() {
                var selectedCountry = document.getElementById("CountryID").value;
                var stateDropdown = document.getElementById("StateID");

                // Clear the current options in the State dropdown
                stateDropdown.innerHTML = "";

                // Make an AJAX request to fetch the states based on the selected country
                $.get(`/Lecturers/GetStatesByCountry/${selectedCountry}`, function (data) {
                    // Create an option for each state
                    for (var i = 0; i < data.length; i++) {
                        var option = document.createElement("option");
                        option.value = data[i].Key;
                        option.text = data[i].Value;
                        stateDropdown.appendChild(option);
                    }

                    // Clear the city dropdown
                    var cityDropdown = document.getElementById("CityID");
                    cityDropdown.innerHTML = '<option value="">Select City</option>';
                }).fail(function (jqXHR, textStatus, errorThrown) {
                    console.log("Error fetching states: " + errorThrown);
                });
            }

            function updateCityDropdown() {
                var selectedState = document.getElementById("StateID").value;
                var cityDropdown = document.getElementById("CityID");

                // Make an AJAX request to fetch the cities based on the selected state
                $.get(`/Lecturers/GetCitiesByState/${selectedState}`, function (data) {
                    cityDropdown.innerHTML = '<option value="">Select City</option>';
                    $.each(data, function (index, item) {
                        var option = document.createElement("option");
                        option.value = item.Key;
                        option.text = item.Value;
                        cityDropdown.appendChild(option);
                    });
                }).fail(function (jqXHR, textStatus, errorThrown) {
                    console.log("Error fetching cities: " + textStatus);
                });
            }

            document.getElementById("CountryID").addEventListener("change", updateStateDropdown);
            document.getElementById("StateID").addEventListener("change", updateCityDropdown);

            // Initial update when loading the page
            updateStateDropdown();
            updateCityDropdown();
        </script>
    }

    </body>
    </html>
}

“这个问题似乎与AJAX请求有关。我怀疑 AJAX 请求中使用的 URL 可能存在问题。当我从下拉列表中选择一个国家/地区时,我遇到了 404 错误,当我选择一个州时也会发生同样的情况。

值得注意的是,当我在下拉列表中选择“印度”时,它会填充三个“未定义”选项,即使数据库中有三个印度州。

我对编程比较陌生,因此非常感谢任何关于解决此问题并成功实现级联下拉列表的指导或建议。

谢谢你的帮助!

JavaScript asp.net ajax asp.net-core .net-core

评论

2赞 Pete 10/25/2023
@html.beginform创建一个表单标签来代替它的括号,所以它应该在正文标签内 - 可能代替你所拥有的位置<form asp-action="Create"></form>
0赞 freedomn-m 10/25/2023
您需要进行一些基本的调试。首先,始终检查呈现的 HTML,以确保您的行生成您期望的 HTML。接下来,在获取变量时调试变量,例如 然后检查浏览器网络选项卡,查看请求的 url 到底是什么 url 给出了 404@Html.console.log("selectedCountry", selectedCountry);
0赞 Sashank 10/25/2023
MVC ASP.NET 中的 Html.BeginForm 帮助程序直接在 HTML 中生成 <form> 标记,并且应在 HTML 文档的 <body> 中使用。使用 Html.BeginForm 时,无需手动添加 <form> 标记。
0赞 Sashank 10/25/2023
我尝试将控制台.log用于国家/地区,并且得到了预期的输出。还是同样的问题
0赞 Pete 10/25/2023
如果您在初始加载时执行此操作,而不是在更新其他下拉列表之一时执行此操作,为什么不直接在服务器端执行此操作并将其传递到模型中

答:

0赞 Qing Guo 10/27/2023 #1

我测试你的代码并重现它,你可以尝试更改

 option.value = data[i].Key;
 option.text = data[i].Value;
 option.value = item.Key;
 option.text = item.Value;

到:

option.value = data[i].key;
option.text = data[i].value;
option.value = item.key;
option.text = item.value; 

结果:enter image description here

评论

0赞 Qing Guo 10/30/2023
嗨@Sashank,有什么更新吗?如果我的回答能帮助您解决问题?如果没有,你能跟进让我知道吗?