前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >关于动态创建DOM元素的问题

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

作者头像
Isaac Zhang
发布2019-09-10 18:37:04
2.2K0
发布2019-09-10 18:37:04
举报
文章被收录于专栏:奔跑的人生奔跑的人生

在我们实际的项目之中,相信有很多的朋友直接使用了以下的格式创建DOM元素

<script type="text/javascript">

document.getElementById("testDiv").innerHTML ="动态创建的div";

代码语言:javascript
复制
</script>

而且用的应该是还是乐此不疲,但是有多少人知道这是错误的做法!
代码语言:javascript
复制

错误的原因:

(1) 在页面加载时改变了页面的结构. 在IE6中如果网络变慢或者页面内容太大就会出现"终止操作"的错误. 也就是说"永远不要在页面加载时改变页面的Dom模型".

(2) 使用修改HTML内容添加元素, 不符合Dom标准. 在实际工作中也碰到过使用这种方法修改内容后, 某些浏览器中并不能立刻显示添加的元素, 因为不同浏览器的显示引擎是不同的. 但是如果我们使用Dom的CreateElement创建对象, 在所有的浏览器中几乎都可以. 但是在jQuery中如果传入的而是一个完整的HTML字符串, 内部也是使用innerHTML. 所以也不是完全否定innerHTML函数的使用.

所以从现在开始请摒弃这种旧知识, 使用下面介绍的正确方法编程.

关于使用HTML DOM创建元素本文不做详细介绍, 下面举一个简单的例子:

代码语言:javascript
复制
第一种正确方式: 
//使用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创建元素:

代码语言:javascript
复制
$("
").css("border","solid 1px #FF0000").html("动态创建的div").appendTo(testDiv);

否则使用innerHTML方法创建元素:

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

代码语言:javascript
复制
$("
动态创建的div
").appendTo(testDiv)
代码语言:javascript
复制
(引自:http://kb.cnblogs.com/page/46453/)
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2010-12-24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档