源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

在jquery中combobox多选的不兼容问题总结

  • 时间:2022-03-29 23:55 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:在jquery中combobox多选的不兼容问题总结
最近在IE10中开发jquery,关于jquery中combobox多选不能兼容的问题,进行一些总结。 当给combobox设置属性“multiple:true”时,IE10无法完成多选,其报错如下:
[u]复制代码[/u] 代码如下:
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.修改源码 将以上代码修改为
[u]复制代码[/u] 代码如下:
<strong>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<l;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); }</strong>
2.加入indexOf方法
[u]复制代码[/u] 代码如下:
<strong>if(!Array.prototype.indexOf){ Array.prototype.indexOf = function(target){ for(var i=0,l=this.length;i<l;i++){ if(this[i] === target) return i; } return -1; }; }</strong>
其实我还是蛮推荐第一种方法的,因为比较方便,我就是用的第一种方式。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部