首页 >后端开发 >C++ >如何使用 jQuery $.post 和 ASP.NET MVC 正确填充 jqGrid 下拉列表?

如何使用 jQuery $.post 和 ASP.NET MVC 正确填充 jqGrid 下拉列表?

Barbara Streisand
Barbara Streisand原创
2025-01-11 07:38:45389浏览

How to Correctly Populate jqGrid Dropdowns Using jQuery $.post and ASP.NET MVC?

使用 jQuery $.post 和 ASP.NET MVC 正确填充 jqGrid 下拉列表

本文解决了使用 jQuery 的 $.post 方法和 ASP.NET MVC 动态填充 jqGrid 下拉列表时的一个常见问题:由于数据格式不正确而收到“未定义”值。

问题: 发送到 jqGrid 的数据格式不正确,导致“未定义”下拉值。 jqGrid 需要特定的格式(例如 value: "FE:FedEx; IN:InTime; TN:TNT"),但请求可能会以不同的格式返回数据。

原始请求和响应:原始方法可能使用 $.post 来获取 JSON 数据。然而,JSON 结构与 jqGrid 的期望不符。 该解决方案涉及在值创建期间删除额外的引号并更改控制器对 ContentResult(sb.ToString()) 的响应。 这是一种不太稳健的方法。

更强大的解决方案:利用 dataUrlbuildSelect

更好的方法是使用 jqGrid 的 dataUrlbuildSelect 功能来获得更干净、更易于维护的代码。

dataUrl: 此属性指定以更简单的格式返回数据的 URL,适合解析。 格式不需要预先格式化为键值对字符串。

buildSelect: 此回调函数处理服务器的响应(最好是 JSON)并构造正确的下拉 HTML。这将数据检索与数据格式化分开,提高了代码组织和可读性。

示例实现:

控制器(ASP.NET MVC):

<code class="language-csharp">public JsonResult GetDestinationList() {
    List<string> allDestinations = GetAllDestinations();
    return Json(allDestinations, JsonRequestBehavior.AllowGet);
}</code>

jqGrid 配置(JavaScript):

<code class="language-javascript">{
    name: 'destinations',
    editable: true,
    edittype: 'select',
    editoptions: {
        dataUrl: '/YourController/GetDestinationList', // Replace with your controller action
        buildSelect: function(data) {
            var s = '';
            if (data.length) {
                for (var i = 0; i < data.length; i++) {
                    var ri = data[i]; // Assuming data is an array of strings
                    s += '<option value="' + ri + '">' + ri + '</option>';
                }
            }
            return s;
        }
    }
}</code>

这种修改后的方法为填充 jqGrid 下拉列表提供了更高效且可维护的解决方案。 服务器返回简单数据,客户端 buildSelect 函数处理格式化,从而更好地分离关注点。请记住将 /YourController/GetDestinationList 替换为控制器操作的实际 URL。

以上是如何使用 jQuery $.post 和 ASP.NET MVC 正确填充 jqGrid 下拉列表?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn