时间:2021-05-25
复制代码 代码如下:
<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)
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
近日,因工作需要,需要通过点击某个元素后,动态创建一个DOM元素并显示,因此写了一些相关的JS函数,在此记录,以作备忘:/*动态创建DOM元素的相关函数
本文实例讲述了JS动态创建DOM元素的方法。分享给大家供大家参考。具体如下:近日,因工作需要,需要通过点击某个元素后,动态创建一个DOM元素并显示,因此写了一些
Jquery实现表格元素的动态创建,本质是通过构造一个DomNode节点,并且拼接到表格的Dom树上的子叶位置。HTML正文:用户:邮箱:手机:添加userma
之前做项目都是直接用jquery的bind绑定事件,不过当时都不是动态生成dom元素,而是已经页面中原本存在的dom元素进行事件绑定,最近在测试给动态生成的do
本文实例讲述了javascript动态创建及删除元素的方法。分享给大家供大家参考。具体分析如下:在DOM中我们可以方便快速的动态删除与删除dom元素,这里我们就