基于jquery的关于动态创建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)

相关文章

问题背景 最近小伙伴提了一个希望提高后台下拉列表可操作性的...
// n位随机数生成 function randomNum(n) { let sString = &...
HTML是HyperText Markup Language的简称,中文名称:超文本标...
层叠样式表(英文全称:Cascading Style Sheets)是一种用来表现...
JavaScript 是脚本语言,是一种解释性脚本语言(代码不进行预...
本文由葡萄城技术团队原创并首发 转载请注明出处:葡萄城官网...