在IE6下使用jquery动态改变select控件值时出错的解决方案

本文详细介绍了在IE6浏览器中使用jQuery处理Select控件时遇到的‘对象不具有selected属性’错误,分析了该错误的根本原因,并提供了具体的解决方法。通过代码示例对比了不同实现方式在IE6下的表现,最终推荐了一种有效且兼容的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在做一个省份城市联动的select控件的时候,在IE6下测试出现“对象不具有selected属性”这样的错误,在代码中间加alert等delay操作这个错误就不再出现了,上网查了下说是IE6的select控件的BUG,

        具体请参考:http://bugs.jquery.com/ticket/2252

 

        网上通常的解决方法请参考下面的链接

        http://www.cnblogs.com/napoleon_liu/archive/2011/03/14/1983773.html

 

        我的解决方法是将之前追加子option的方法从select.html(optionStr)

 

        改变为selectC.add(new Option(text,value),$.browser.msie ? 0 : selectC.options[0]);

 

 

       下面是一段简单的代码,大家可以测试一下,使用.html这种方法在IE6上会出错,改成add方法就正常。

 

 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
  <head>
    <title>$.browser Example</title>
    <link rel="stylesheet" type="text/css" href="../common.css">
    <script type="text/javascript"
            src="jquery-1.6.2.js"></script>
    <script type="text/javascript">
      $(function(){
        $('#province').change(function(event){
          var select = $('#province')[0];
		  
		  var selectC = $('#city')[0];
		  //var optionS = "<option value='2.5'>Two and \u00BD</option>";
		  //$(selectC).html(optionS);
		  selectC.add(
            new Option('Two and \u00BD','2.5'),
            $.browser.msie ? 0 : selectC.options[0]
          );
		 
		  $(selectC).val("2.5")
        });
      });
    </script>
  </head>

  <body class="plain">
    <select id="province">
      <option value="1">One</option>
      <option value="2">Two</option>
      <option value="3">Three</option>
      <option value="4">Four</option>
    </select>
	<select id="city">
    </select>
  </body>
</html>

 

说明 这个控件实现相当简单,基于jQuery实现,只编写一些基本功能,满足一般使用。提供原代码,可以根据自己的项目要求修改,只在IE6IE7、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); } 测试 省: 市: 区: 普通模糊右边模糊普通模糊右边模糊普通模糊右边模糊
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值