jqGrid中下拉框的实现(The realization of select in jqGrid via C#)

 

这几天需要用到用到jqGrid,所以就用到了jqGrid中的下拉框。而下拉框的值是取自其他数据库表

 

【解决方法】:

 

jqGrid的select的使用语法为:

 

{name:'myname', edittype:'select', editoptions:{value:{1:'One',2:'Two'}} },

 

edittype为select,editoptions是展示的值。【详细信息参考】:http://www.trirand.com/jqgridwiki/doku.php?id=wiki:common_rules#edittype

 

实现方式有:

 

  (1)

 

editoptions: { value: “FE:FedEx; IN:InTime; TN:TNT” } 

 

【注意】:最后没有分号";"

 

其等效于:

<select> 
<option value='FE'> FedEx </option> 
<option value='IN'> InTime </option> 
<option value='TN'> TNT </option> 
</select>

 

 

(2)

editoptions:{value:{1:'One',2:'Two'}}

 

【注意】:最后没有分号。

 

相当于HTML中

<select> 
<option value='1'>One</option> 
<option value='2'>Two</option> 
</select>

 

我使用的是第一种实现方式。

 

实现代码如下:

 

{ name: 'PHAR_CODE', index: 'PHAR_CODE', width: 100, editable: true, edittype: 'select', editrules: { required: true }, editoptions: { value: getMedicalGroups()} },

 

getMedicalGroups()方法的实现如下:

function getMedicalGroups(dicTypeId) {
    var returnStr = "";
    $.ajax({
        async: false,
        type: "get",
        url: "/DrugInfo/DrugDetails/DrugMedicalInfo/GetDictionaryByTypeID?dictionaryTypeId=" + dicTypeId,
        success: function (rJson) {
            var rObj = $.parseJSON(rJson);
            for (i = 0; i < rObj.data.length; i++) {
                if (i < rObj.data.length - 1) {
                    returnStr += rObj.data[i].dictionaryID + ":" + rObj.data[i].dictionaryName + ";";
                } else {
                    returnStr += rObj.data[i].dictionaryID + ":" + rObj.data[i].dictionaryName;
                }
            }
        }
    });      //End Ajax
    return returnStr;
}

  

【结束】

 

基本思想就是这样,但因为不同的项目,JSON的构成可能不同。在我们项目中JSON由三部分组成,一是标志位success、二是用于存储信息的message、三是用于存储的data,所以,在我的程序中用到了

 

rObj.data.length。

 

运行效果:


 

实现 jqgrid 表头的筛选下拉框,可以按照以下步骤操作: 1. 在 colModel 设置 stypeselect,如下: ``` { name: 'xxx', index: 'xxx', stype: 'select', searchoptions: { value: ':All;1:Option1;2:Option2;3:Option3' } } ``` 其,value 属性的字符串是下拉框的选项,格式为 label:value,多个选项之间用分号隔开,第一个选项必须为 All(或者 Any),表示所有选项。 2. 在 jqGrid 的 options 添加如下代码: ``` { // ... postData: { filters: function () { var columnData = $("#grid").jqGrid('getGridParam', 'postData').columns; var postData = JSON.stringify({ groupOp: "AND", rules: [{ field: columnData[0].name, op: "eq", data: columnData[0].searchValue }, { field: columnData[1].name, op: "eq", data: columnData[1].searchValue }] }); return postData; } }, // ... } ``` 其,postData 的 filters 属性用于设置筛选条件,rules 数组的每个元素表示一个筛选条件,包含三个属性:field(列名)、op(操作符)、data(筛选值)。这里的 columnData 是获取当前 jqGrid 的 postData 的 columns 属性。 3. 在 jqGrid 的 options 设置 search 属性为 true: ``` { // ... search: true, // ... } ``` 4. 在 jqGrid 添加一个按钮,用于触发表头筛选: ``` $("#grid").jqGrid('navGrid', '#pager', { edit: false, add: false, del: false, search: false }) .jqGrid('navButtonAdd', '#pager', { caption: "Search", title: "Toggle Searching Toolbar", buttonicon: 'ui-icon-search', onClickButton: function () { $("#grid")[0].toggleToolbar(); } }); ``` 这样就可以实现 jqgrid 表头的筛选下拉框了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值