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

在我们实际的项目之中,相信有很多的朋友直接使用了以下的格式创建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)
(引自:http://kb.cnblogs.com/page/46453/)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏运维之美

每天都在用的浏览器,你知道它是如何工作的吗?

浏览器经历了很多年的发展,浏览器引擎也在不停地迭代和演进。从PC时代到移动端,以独立浏览器的形态还是以系统WebView组件内嵌的形态存在,在互联网的生态系统中...

17620
来自专栏小灰灰

SpringBoot系列教程web篇之Thymeleaf环境搭建

上一篇博文介绍了如何使用Freemaker引擎搭建web项目,这一篇我们则看一下另外一个常见的页面渲染引擎Thymeleaf如何搭建一个web项目

9510
来自专栏达达前端

微信小程序根据状态换图

若本号内容有做得不到位的地方(比如:涉及版权或其他问题),请及时联系我们进行整改即可,会在第一时间进行处理。----

5320
来自专栏Web前端开发

querySelector和getElementById方法的区别

这两个新添加的 API 与 getElementById() / getElementsByTagName() 有什么区别呢?

29910
来自专栏不为人知的前端技巧

这些不常用的Web API真的有用吗? 别问,问就是有用🈶

本文列举了一些列比较不常见的Web API,内容较多,所以有关兼容性的内容在本文不会出现,大家可以自己去查阅。 以下案例能配动图的我尽量去配了,以免内容枯草乏味...

10220
来自专栏逸繁

常用正则总结

29110
来自专栏Web前端开发

CSS3背景与渐变

15120
来自专栏Web前端开发

跨域的简介与解决方案

跨域是指一个域下的文档或脚本试图去请求另一个域下的资源(只要域名、协议和端口有任一个不同,就被当作是跨域)

16910
来自专栏达达前端

微信小程序音乐播放器组件

若本号内容有做得不到位的地方(比如:涉及版权或其他问题),请及时联系我们进行整改即可,会在第一时间进行处理。----

22010
来自专栏小灰灰

SpringBoot系列教程web篇之Beetl环境搭建

前面两篇分别介绍了目前流行的模板引擎Freemaker和Thymeleaf构建web应用的方式,接下来我们看一下号称性能最好的国产模板引擎Beetl,如何搭建w...

21930

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励