”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么我的 jqGrid 编辑表单中的状态选择框选项值不正确?

为什么我的 jqGrid 编辑表单中的状态选择框选项值不正确?

发布于2024-11-08
浏览:929

Why are the State select box option values incorrect in my jqGrid edit form?

jqgrid 在编辑框中选择下拉选项值不正确

尽管在编辑表单中正确选择了“国家/地区”和“州”值,但“州”选择框中显示的选项值编辑表格时不正确。即使选择美国国家/地区后切换回英国国家/地区,此问题仍然存在。

如何解决“州”选择框中不正确的选项值

要解决此问题,需要正确加载编辑表单时,根据所选国家/地区值填充州选择框。该方法涉及:

  1. 根据 dataInit 函数中的国家/地区选择填充州值。
  2. 如果国家/地区更改,则重建州选择框。

代码解决方案

var countries = { '1': 'US', '2': 'UK' };
var states = { '1': 'Alabama', '2': 'California', '3': 'Florida', '4': 'Hawaii', '5': 'London', '6': 'Oxford' };
var statesOfCountry = {
    1: { '1': 'Alabama', '2': 'California', '3': 'Florida', '4': 'Hawaii' },
    2: { '5': 'London', '6': 'Oxford' }
};

var resetStatesValues = function () {
    grid.setColProp('State', { editoptions: { value: states} });
};

$("#list").jqGrid({
    data: mydata,
    datatype: 'local',
    colModel: [
        { name: 'Name', width: 200 },
        { 
            name: 'Country', 
            width: 100, 
            editable: true, 
            formatter: 'select',
            edittype: 'select', 
            editoptions: {
                value: countries,
                dataInit: function (elem) {
                    setStateValues($(elem).val());
                },
                dataEvents: [
                    { type: 'change', fn: function (e) { changeStateSelect($(e.target).val(), e.target); } },
                    { type: 'keyup', fn: function (e) { $(e.target).trigger('change'); } }
                ]
            }
        },
        {
            name: 'State', 
            width: 100, 
            editable: true, 
            formatter: 'select',
            edittype: 'select', 
            editoptions: { value: states }
        }
    ],
    onSelectRow: function (id) {
        if (id && id !== lastSel) {
            if (lastSel != -1) {
                resetStatesValues();
                grid.restoreRow(lastSel);
            }
            lastSel = id;
        }
    },
    ondblClickRow: function (id, ri, ci) {
        if (id && id !== lastSel) {
            grid.restoreRow(lastSel);
            lastSel = id;
        }
        resetStatesValues();
        grid.editRow(id, true, null, null, 'clientArray', null,
                        function (rowid, response) {  // aftersavefunc
                            grid.setColProp('State', { editoptions: { value: states} });
                        });
        return;
    },
    editurl: 'clientArray',
    sortname: 'Name',
    height: '100%',
    viewrecords: true,
    rownumbers: true,
    sortorder: "desc",
    pager: '#pager',
    caption: "Demonstrate dependend select/dropdown lists (edit on double-click)"
}).jqGrid('navGrid','#pager', 
          { edit: true, add: true, del: false, search: false, refresh: false },
          { // edit options
              recreateForm:true,
              onClose:function() {
                  resetStatesValues();
              }
          },
          { // add options
              recreateForm:true,
              onClose:function() {
                  resetStatesValues();
              }
          });

注释

  • grid.setColProp(...)方法用于设置列属性。
  • dataInit函数用于初始化选择框并用选项填充它。
  • dataEvents 数组用于将事件处理程序附加到选择框。
最新教程 更多>
  • 如何使用Python有效地以相反顺序读取大型文件?
    如何使用Python有效地以相反顺序读取大型文件?
    在python 中,如果您使用一个大文件,并且需要从最后一行读取其内容,则在第一行到第一行,Python的内置功能可能不合适。这是解决此任务的有效解决方案:反向行读取器生成器 == ord('\ n'): 缓冲区=缓冲区[:-1] ...
    编程 发布于2025-04-29
  • C#中Int与Int32:选哪个整数类型?
    C#中Int与Int32:选哪个整数类型?
    C# 中 int 和 Int32 的使用 在 C# 中处理整数时,您可能会遇到两个术语:int 和 Int32。这两个术语代表相同的数据类型,都存储 32 位整数。然而,一个常见的问题是:应该使用 int 还是 Int32? 虽然 int 和 Int32 的功能完全相同,但某些考虑因素可以指导您的...
    编程 发布于2025-04-29
  • 哪种在JavaScript中声明多个变量的方法更可维护?
    哪种在JavaScript中声明多个变量的方法更可维护?
    在JavaScript中声明多个变量:探索两个方法在JavaScript中,开发人员经常遇到需要声明多个变量的需要。对此的两种常见方法是:在单独的行上声明每个变量: 当涉及性能时,这两种方法本质上都是等效的。但是,可维护性可能会有所不同。 第一个方法被认为更易于维护。每个声明都是其自己的语句,使其...
    编程 发布于2025-04-29
  • 对象拟合:IE和Edge中的封面失败,如何修复?
    对象拟合:IE和Edge中的封面失败,如何修复?
    To resolve this issue, we employ a clever CSS solution that solves the problem:position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%)...
    编程 发布于2025-04-29
  • 如何使用node-mysql在单个查询中执行多个SQL语句?
    如何使用node-mysql在单个查询中执行多个SQL语句?
    Multi-Statement Query Support in Node-MySQLIn Node.js, the question arises when executing multiple SQL statements in a single query using the node-mys...
    编程 发布于2025-04-29
  • MySQL中如何高效地根据两个条件INSERT或UPDATE行?
    MySQL中如何高效地根据两个条件INSERT或UPDATE行?
    在两个条件下插入或更新或更新 solution:的答案在于mysql的插入中...在重复键更新语法上。如果不存在匹配行或更新现有行,则此功能强大的功能可以通过插入新行来进行有效的数据操作。如果违反了唯一的密钥约束。实现所需的行为,该表必须具有唯一的键定义(在这种情况下为'名称'...
    编程 发布于2025-04-29
  • 您如何在Laravel Blade模板中定义变量?
    您如何在Laravel Blade模板中定义变量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配变量对于存储以后使用的数据至关重要。在使用“ {{}}”分配变量的同时,它可能并不总是最优雅的解决方案。幸运的是,Blade通过@php Directive提供了更优雅的方法: $ old_section =“...
    编程 发布于2025-04-29
  • Entity Framework 5更新记录的最佳方法
    Entity Framework 5更新记录的最佳方法
    Entity Framework 5记录更新的最佳实践 在Entity Framework 5中更新记录,开发者常常面临多种方法的选择,每种方法都有其优缺点。本文将探讨三种常用方法及其局限性,并最终给出最佳方案。 方法一:加载原始记录并逐个更新属性 此方法需要先加载原始记录,然后手动更新每个修改后...
    编程 发布于2025-04-29
  • C#静态变量如何工作及为何不能在方法内声明
    C#静态变量如何工作及为何不能在方法内声明
    C#中的静态变量 许多开发人员难以理解C#中静态变量的功能。本文旨在阐明它们的用途和用法,同时解释为什么不能在方法内部声明静态变量。 什么是静态变量? 静态变量是类级别的变量,在该类的所有实例之间共享。其值在从该类创建的所有对象之间共享。 何时使用静态变量? 在需要跨类的多个实例维护值的情况下,通...
    编程 发布于2025-04-29
  • 如何在JavaScript对象中动态设置键?
    如何在JavaScript对象中动态设置键?
    在尝试为JavaScript对象创建动态键时,如何使用此Syntax jsObj['key' i] = 'example' 1;不工作。正确的方法采用方括号: jsobj ['key''i] ='example'1; 在JavaScript中,数组是一...
    编程 发布于2025-04-29
  • IACA助力优化Intel CPU代码性能分析
    IACA助力优化Intel CPU代码性能分析
    被称为英特尔体系结构代码分析仪,IACA是用于评估针对Intel CPU的代码调度的高级工具。它以三种模式运行: 吞吐量模式: iaca iaca衡量最大的吞吐量,假设它是嵌套循环的主体。 IACA traces the sequence of instructions as they progr...
    编程 发布于2025-04-29
  • 为什么使用Firefox后退按钮时JavaScript执行停止?
    为什么使用Firefox后退按钮时JavaScript执行停止?
    导航历史记录问题:JavaScript使用Firefox Back Back 此行为是由浏览器缓存JavaScript资源引起的。要解决此问题并确保在后续页面访问中执行脚本,Firefox用户应设置一个空功能。 警报'); }; alert('inline Alert')...
    编程 发布于2025-04-29
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call ...
    编程 发布于2025-04-29
  • Java GUI计算器中如何使用getSource()获取数字按钮值?
    Java GUI计算器中如何使用getSource()获取数字按钮值?
    如何使用getSource() 要检索每个按钮的值,请按照以下步骤操作: 当前的code bud y you budsors。 ETC。)。为数字按钮(例如NumactionListener)创建一个单独的操作侦听器。 为号码按钮注册操作侦听器。将NumactionListener添加到所有数字按...
    编程 发布于2025-04-29
  • Java字符串非空且非null的有效检查方法
    Java字符串非空且非null的有效检查方法
    检查字符串是否不是null而不是空的 if(str!= null && str.isementy())二手: if(str!= null && str.length()== 0) option 3:trim()。isement(Isement() trim whitespace whitesp...
    编程 发布于2025-04-29

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3