百度空间 | 百度首页 
 
查看文章
 
IE里input元素type为checkbox与radio的checked=true失效
2008-12-15 16:52

Bansi: 最近碰到的一个问题,IE里面使用createElement方式生成input元素,并设置checked=true;结果IE里失效,checkbox、radio选择框并没有被选择起来。找到一篇文章,里面提供了解决思路。但是,还有一个问题,按照下文的方法能够解决IE的问题,FF里又来问题了。下看原文,最后提供一个我的解决方案供参考与交流。

使用DOM来创建页面元素的一些问题(转)
原文地址:http://blog.csdn.net/yangdengfeng2003/archive/2007/05/05/1597426.aspx
在IE中使用DOM方式来动态创建页面元素的时候,我发现了一些问题。记录于此,如果您有好的意见欢迎提供,如果您也遇到此问题,希望能有助你解决。

    对于动态HTML编程,IE实现了两套模型:一套是以操作innerHTML为主的狭义的DHTML,一套是以集合方式操作(appendChild)页面元素对象的DOM(Document Object Model)。DHTML方式(我本文说的DHTML都默认指的对于innerHTML进行操作的编程方式,不是广义的DHTML。)直接操作html代码片断,主要靠Web程序员使用字符串拼接来生成页面元素,这是一种高效的动态页面操作方式,不过似乎少些编程逻辑的味道,代码中往往散布着大量不完整的html代码片断。而DOM方式进行动态页面编程,在逻辑上是一种对集合和元素对象的操作,编程逻辑比较清晰,不过效率上有一些差别。具体使用什么方式来实现动态Web页面,大多数情况下是个人的喜好问题,除非在效率上必须锱铢必较。

    使用DOM,最常用的方法就是document.createElement(sTag),sTag是一个合法的html标签名字(tagName)。我们创建好一个html元素对象后,对它的属性进行赋值,然后insertBefore或appendChild到页面的DOM对象树中。这里msdn提醒了几个注意事项:

    1、不能通过编程方式动态创建frame和iframe元素(IE 5.0及以下);
    2、input元素被创建后默认的类型是input type='text';
    3、需要使用其他类型的input元素,需要在把input对象放入DOM对象树之前给input.type赋予你希望的类型,否则在input insert或append进入DOM对象树后不能再修改;
    4、button元素被创建后默认的类型是普通按钮,要使用其它类型按钮,需要遵循和问题3相同的注意事项;
    5、不能为通过向元素对象赋值得方式,为元素对象添加NAME属性(这个在"细说HTML元素的ID和NAME属性详解"一文里也是提过的)。
    6、sTag其实不只限于html标签名,任何合法的html元素语句都可以。

    下面说一下我遇到的问题,当我在使用DOM方式进行动态页面创建的时候,发现不能使用普通的DOM方式为input type='checkbox'和input type='radio'赋初值。即下面的语句:

var input = document.createElement('INPUT');
input.type
= 'checkbox';
input.checked
= true;
document.body.appendChild(input);

input
= document.createElement('INPUT');
input.type
= 'radio';
input.checked
= true;
document.body.appendChild(input);

    不能得到我期望的效果: ,而只能得到: 。

     而要得到我期望的效果,需要混合DHTML和DOM两种方式就是说我必须在sTag里就构建好的属性,使用如下代码:

var input = document.createElement('<INPUT checked>');
input.type
= 'checkbox';
document.body.appendChild(input);

input
= document.createElement('<INPUT checked>');
input.type
= 'radio';
document.body.appendChild(input);

    才能得到被赋予初值得INPUT元素: 。

解决方法1:使用JS语句判断浏览器类型,根据不同的浏览器生成不同的代码。

    if(document.all){
                var input=document.createElement('<input checked>');//IE代码
            }else{
                var input=document.createElement('input'); //其他
     input.checked=true;
            }

解决方法2:使用innerHTML方式生成input元素,并设置其属性跟方法。

该方式,经过实际测试,对IE跟FF来说都是一致的。


类别:Javascript | 添加到搜藏 | 浏览() | 评论 (0)
 
最近读者:
 
网友评论:
发表评论:
姓 名:
网址或邮箱: (选填)
内 容:
验证码: 请点击后输入四位验证码,字母不区分大小写
      

     

©2009 Baidu