基于jquery的关于动态创建DOM元素的问题

转自: http://www.jb51.net/article/25721.htm ( 原文更易阅读

在我们实际的项目之中,相信有很多的朋友直接使用了以下的格式创建DOM元素。
复制代码 代码如下:
<script type="text/javascript"> 
document.getElementById("testDiv").innerHTML ="动态创建的div"; 
</script> 


而且用的应该是还是乐此不疲,但是有多少人知道这是错误的做法!错误的原因: 
(1) 在页面加载时改变了页面的结构. 在IE6中如果网络变慢或者页面内容太大就会出现"终止操作"的错误. 也就是说"永远不要在页面加载时改变页面的Dom模型". 
(2) 使用修改HTML内容添加元素, 不符合Dom标准. 在实际工作中也碰到过使用这种方法修改内容后, 某些浏览器中并不能立刻显示添加的元素, 因为不同浏览器的显示引擎是不同的. 但是如果我们使用Dom的CreateElement创建对象, 在所有的浏览器中几乎都可以. 但是在jQuery中如果传入的而是一个完整的HTML字符串, 内部也是使用innerHTML. 所以也不是完全否定innerHTML函数的使用.所以从现在开始请摒弃这种旧知识, 使用下面介绍的正确方法编程. 
关于使用HTML DOM创建元素本文不做详细介绍, 下面举一个简单的例子:第一种正确方式: 
复制代码 代码如下:
//使用Dom标准创建元素 
var select = document.createElement("select"); 
select.options[0] = new Option("加载项1", "value1"); 
select.options[1] = new Option("加载项2", "value2"); 
select.size = "2"; 
var object = testDiv.appendChild(select); 


通过使用 document.createElement 方法我们可以创建Dom元素, 然后通过appendChild方法为添加到指定对象上. 
第二种方式: 使用Jquery 
当HTML字符串是没有属性的元素是, 内部使用document.createElement创建元素, 比如: 


//jQuery内部使用document.createElement创建元素: 




$("").css("border","solid 1px #FF0000").html("动态创建的div").appendTo(testDiv); 
否则使用innerHTML方法创建元素: 


//jQuery内部使用innerHTML创建元素: 


$("动态创建的div").appendTo(testDiv) 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值