关於在jquery的JSON数据,数组与easyui combobox问题
发布网友
发布时间:2022-04-25 18:18
我来回答
共2个回答
懂视网
时间:2022-04-25 22:40
最近在IE10中开发jquery,关于jquery中combobox多选不能兼容的问题,进行一些总结。
当给combobox设置属性“multiple:true”时,IE10无法完成多选,其报错如下:
代码如下:
function _7e8(_7e9,_7ea){
var _7eb=$.data(_7e9,"combobox");
var opts=_7eb.options;
var _7ec=$(_7e9).combo("getValues");
var _7ed=_7ec.indexOf(_7ea+"");//10650行 这里报错
if(_7ed>=0){
_7ec.splice(_7ed,1);
_7e7(_7e9,_7ec);
也就是在F12中报不支持indexOf方法,现在对这种问题有两种解决方案:
1.修改源码
将以上代码修改为
代码如下:
function _7e8(_7e9,_7ea){
var _7eb=$.data(_7e9,"combobox");
var opts=_7eb.options;
var _7ec=$(_7e9).combo("getValues");
var _7ed = (function(arr,str){
str = str + "";
for(var i=0,l=arr.length;i
if(arr[i] == str) return i;
}
return -1;
})(_7ec,_7ea);
if(_7ed >= 0){//修改于 2013-6-25 19:04
_7ec.splice(_7ed,1);
_7e7(_7e9,_7ec);
}
2.加入indexOf方法
代码如下:
if(!Array.prototype.indexOf){
Array.prototype.indexOf = function(target){
for(var i=0,l=this.length;iif(this[i] === target) return i;
}
return -1;
};
}
其实我还是蛮推荐第一种方法的,因为比较方便,我就是用的第一种方式。
热心网友
时间:2022-04-25 19:48
var data = [];
fields = $('#dg').datagrid ('getColumnFields'); // 得到一组datagrid的列名
for ( var i = 1; i < fields.length; i++ ) {
title = $('#dg').datagrid('getColumnOption', fields[i]);// 得到标题
for (var j = 0; j < title.length; j++) {
data.push({"fields": fields[i], "title": title[j]});
}
}
$('#cc').combobox({
url:data,
valueField:'fields,
textField:'title'
});