zoukankan      html  css  js  c++  java
  • 关于动态创建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/)
  • 相关阅读:
    单元测试之NUnit一
    第一个基于ArcGIS的Android应用
    NuGet的安装和使用
    PIE调用Python获得彩色直方图
    PIE调用Python返回得到直方图矩阵数组
    PIE属性表多字段的文本绘制
    微信公众号配置和使用客服消息
    python多线程爬取斗图啦数据
    微信小微商户获取申请状态
    微信小微商户申请入驻
  • 原文地址:https://www.cnblogs.com/zhangpan1244/p/1915741.html
Copyright © 2011-2022 走看看