JQuery在IE8兼容性视图模式下操作Select的Options的Bug

Bug现场:

通过开发人员工具查看,下拉列表框是有Options的,但你点击选择的时候却什么也不显示。

 

重现步骤:

该问题发生在级联下拉框的情况,第一个列表改变,第二个列表的值跟着改变!

本例中使用以下方法绑定数据:

//绑定下拉框
//ctnSelector:下拉框ID,带#号, 
//jsonData:JSON数据, 
//txtField:文本字段名称, 
//valField:值字段名称, 
//strOptions:默认填加的项
function InitSelectOptions(ctnSelector, jsonData, txtField, valField, strOptions) {
    if ($(ctnSelector).length == 0) { return false; };

    $(ctnSelector).html('');
    var optList = strOptions;

    if (typeof (jsonData) != undefined) {
        for (var jitem in jsonData) {
            if (jitem == "insertAt" || jitem == "removeAt" || jitem == "moveTo") {
                continue; //解决flareJ.Base.js导致的问题。
            }
            optList += "<option value='" + jsonData[jitem][valField] + "'>" + jsonData[jitem][txtField] + "</option>";
        }
    }

    $(ctnSelector).html(optList);
}

正常加载时不会出现任何问题!

但当因第一个下拉框的值改变,而第二个下拉框的选项都被清空了,

然后你还是去点第二个下拉框试图去选择一项后,

再去更改第一个下拉框的选项,

你会发现之前第二个下拉框中显示的与第一个下拉框对应的项却怎么也显示不出来了,

只能显示第一个,或是通过脚本设置为选中的一个!

 

解决方案:

使用DOM的方法去操作Options,代码如下:

//绑定下拉框
//ctnSelector:下拉框ID,带#号, 
//jsonData:JSON数据, 
//txtField:文本字段名称, 
//valField:值字段名称, 
//strOptions:默认填加的项
function InitSelectOptions(ctnSelector, jsonData, txtField, valField, strOptions) {
    if ($(ctnSelector).length == 0) { return false; };
    $(ctnSelector).empty();

    var sel = $(ctnSelector).get(0);
    var newOpt = $(strOptions);
    var newOption1 = document.createElement("OPTION");
    newOption1.text = newOpt.text();
    newOption1.value = newOpt.val();
    sel.options.add(newOption1);

    if (typeof (jsonData) != undefined) {
        for (var jitem in jsonData) {
            if (jitem == "insertAt" || jitem == "removeAt" || jitem == "moveTo") {
                continue; //解决flareJ.Base.js导致的问题。
            }
            var newOption = document.createElement("OPTION");
            newOption.text = jsonData[jitem][txtField];
            newOption.value = jsonData[jitem][valField];
            sel.options.add(newOption);
        }
    }
}


 

说明 这个控件实现相当简单,基于jQuery实现,只编写一些基本功能,满足一般使用。提供原代码,可以根据自己的项目要求修改,只在IE6、IE7、IE8、IE9中测试。有问题联系邮箱:zliuyao2010@163.com 初始化构造 构造方法在:input表单添加class="e_select"属性 属性说明:class="e_select" 构造下拉框 属性说明:etop="0" 控件下图片位置,默认可以不用添加此属性。 属性说明:edata="{,普通:普通AA,模糊:模糊,右边模糊:右边模糊}" or {"":"","男":"男1","女":"女1","其他":"其他1"} 下拉框控件中的值,注意:支持两种赋值,json格式以及键值对形式,PS:若下拉列表中有空值键对用英文的“,”,json格式用:"":""。 属性说明:echange="echange" 选择下拉值的回调方法名称,PS:只要输入方法名称,调用方法中有两个参数key(键) 和 value(值) 例如:function echange(key,value) {alert(key + " " + value);} 动态赋值 function setValue() { jQuery("#text1").val("").attr("data","");//赋值请清空原来的值(很重要) jQuery("#text1").attr("edata",'{"":"","男":"男1","女":"女1","其他":"其他1"}'); } 获取值 function getValue() { alert("key:"+document.getElementById("text1").value + " value:" + document.getElementById("text1").data); } 事件 function echange(key,value) { alert("key:"+key + " " + "value:"+value); } 测试 省: 市: 区: 普通模糊右边模糊普通模糊右边模糊普通模糊右边模糊
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值