DOM的核心总结
1、创建元素的三种方式
-
document.write ()
-
element.innerHTML
-
document.createElement ()
区别
-
document.write直接将内容写入页面的内容流,但是文档流执行完毕,则它会导致页面全部重绘
-
innerHTML 是将内容写入某个DOM节点,不会导致页面全部重绘
-
innerHTML 创建多个元素效率更高(不要拼接字符串,采取数组形式拼接),结构稍微复杂
-
createElement() 创建多个元素效率稍低一点点, 但是结构更清晰
总结:不同浏览器下,innerHTML 效率要比creatElement 高
<script>
// 三种创建元素方式区别
// 1. document.write() 创建元素 如果页面文档流加载完毕,再调用这句话会导致页面重绘
var btn = document.querySelector('button');
btn.onclick = function() {
document.write('<div>123</div>');
}
// 2. innerHTML 创建元素
var inner = document.querySelector('.inner');
for (var i = 0; i <= 100; i++) {
inner.innerHTML += '<a href="#">百度</a>'
}
var arr = [];
for (var i = 0; i <= 100; i++) {
arr.push('<a href="#">百度</a>');
}
inner.innerHTML = arr.join('');
// 3. document.createElement() 创建元素
var create = document.querySelector('.create');
for (var i = 0; i <= 100; i++) {
var a = document.createElement('a');
create.appendChild(a);
}
</script>
2、innerTHML和createElement效率对比
innerHTML字符串拼接方式(效率低)
<script>
function fn() {
var d1 = +new Date();
var str = '';
for (var i = 0; i < 1000; i++) {
document.body.innerHTML += '<div style="width:100px; height:2px; border:1px solid blue;"></div>';
}
var d2 = +new Date();
console.log(d2 - d1);
}
fn();
</script>
createElement方式(效率一般)
<script>
function fn() {
var d1 = +new Date();
for (var i = 0; i < 1000; i++) {
var div = document.createElement('div');
div.style.width = '100px';
div.style.height = '2px';
div.style.border = '1px solid red';
document.body.appendChild(div);
}
var d2 = +new Date();
console.log(d2 - d1);
}
fn();
</script>
innerHTML数组方式(效率高)
<script>
function fn() {
var d1 = +new Date();
var array = [];
for (var i = 0; i < 1000; i++) {
array.push('<div style="width:100px; height:2px; border:1px solid blue;"></div>');
}
document.body.innerHTML = array.join('');
var d2 = +new Date();
console.log(d2 - d1);
}
fn();
</script>
3、 DOM的核心总结
文档对象模型(Document Object Model,简称DOM),是W3C组织推荐的处理可扩展标记语言
(HTML或者XML)的标准编程接口。
W3C已经定义了一系列的DOM接口,通过这些DOM接口可以改变网页的内容、结构和样式。
关于dom操作,我们主要针对于元素的操作。主要有创建、增、删、改、查、属性操作、事件操作。
3.1. 创建
-
-
innerHTML
-
3.2. 增加
3.3. 删
removeChild
3.4. 改
主要修改dom的元素属性,dom元素的内容、属性, 表单的值等
-
-
修改普通元素内容: innerHTML、 innerText
-
修改表单元素: value、 type、 disabled等
-
修改元素样式: style、 className
3.5. 查
主要获取查询dom的元素
-
DOM提供的API 方法: getElementByld、 getElementsByTagName 古老用法不太推荐
-
H5提供的新方法: querySelector、 querySelectorAll 提倡
-
3.6. 属性操作
主要针对于自定义属性。
-
sttribute:设置dom的属性值
-
getAttibut:得到dom的属性值
-
removettribute移除属性
3.7. 事件操作(重点)