获取元素
window.idxxx // idxxxx
document.getElementById('idxxx')
document.getElementsByTagName('div')[0]
document.getElementsByClassName('red')[0]
document.querySelector('#idxxx')
document.querySelectorAll('.red')[0]
document.documentElement // 获取html元素
document.head // 获取head元素
document.body // 获取body元素
window // 获取窗口
document.all // 获取所有元素 (第六个falsy值)
元素的6层原型链
data:image/s3,"s3://crabby-images/99605/9960588c8cb0a500b89b9a793e2e4742a3e84a52" alt=""
第一层原型:
HTMLDivElement.prototype
第二层原型:HTMLElement.prototype
第三层原型:Element.prototype
第四层原型:Node.prototype
第五层原型:EventTarget.prototype
第六层原型:Object.prototype
增删改查
- 增
// 创建一个标签节点
let div1 = document.createElement('div')
document.createElement('style')
document.createElement('script')
document.createElement('li')
// 创建一个文本节点
text1 = document.createTextNode('你好')
// 标签里面插入文本
div1.appendChild(text1)
div1.innerText = 'hello'
div1.textContent = 'hi'
// 标签插入到页面,必须插入到head或body中才会生效
document.body.appendChild(div)
已在页面中的元素.appendChild(div)
Test:页面中有
div#test1
和div#test2
,div最终出现在何处?
答案: test2里面,因为一个元素不能出现在两个地方,除非复制一份
let div = document.createElement('div')
test1.appendChild(div)
test2.appendChild(div)
data:image/s3,"s3://crabby-images/ed078/ed07879d78a42fae1c806c7205477a58a14a5803" alt=""
- 删
parentNode.removeChild(childNode)
childNode.remove()
data:image/s3,"s3://crabby-images/f0513/f05136de57597b97ba8771b0626ef36b5a5ba457" alt=""
- 改
data:image/s3,"s3://crabby-images/545a9/545a9d3a53cf137a415143129bfba1dc62fcd1d7" alt=""
data:image/s3,"s3://crabby-images/ed6a5/ed6a51c5ff8846a8686e1cd7ef74d3666da75c8a" alt=""
<div id="test">fafa</div>
console.log(test.onclick)
test.onclick= function(x){
console.log(this)
console.log(x)
}
div.onclick
默认为null
,默认点击div
不会有任何事情发生,但是把div.onclick
改为一个函数fn
。那么点击div
时浏览器就会调用函数fnfn.call(div,event)
div被当做this,event则包含了点击事件的所有信息
data:image/s3,"s3://crabby-images/03453/03453f8aec05fe3b3089cb3baef1352ed6f514cc" alt=""
// 改文本内容
div.innerText = 'xxx'
div.textContent = 'xxx'
// 改HTML内容
div.innerHTML = ‘<strong>aa</strong>’
// 改标签
div.innerHTML = ‘’ // 先清空
div.appendChild(div2) // 再加内容
- 查
// 查看父元素
node.parentNode
node.parentElement
// 查看子元素
node.children
node.childNodes // 包括文本节点
// 查看子代
node.childNodes
node.children
// 查看第一个子元素
node.firstChild
node.firstElementChild
// 查看最后一个子元素
node.lastChild
node.lastElementChild
// 查看上一个元素
node.previousSibing
node.previousElementSibling
// 查看下一个元素
node.nextSibing
node.nextElementSibling
// 查看同一父元素的元素
node.parentElement.children
node.parentNode.childNodes
// 遍历div里面所有元素
travel = (node,fn) =>{
fn(node)
if(node.children){
for(let i=0;i<node.children.length;i++){
travel(node.children[i],fn)
}
}
}
travel(div1,(node)=>console.log(node))
data:image/s3,"s3://crabby-images/9dff2/9dff28e815c93bf740fff2b400a3ba6140003c6a" alt=""
data:image/s3,"s3://crabby-images/8b611/8b611cb24f1ca58eeca5133af5e91e20369e37f0" alt=""
data:image/s3,"s3://crabby-images/4090f/4090f72e8f75e848797a96ab65f608768fbaf9fb" alt=""
DOM操作跨线程
- 跨线程操作
JS引擎不能操作页面,只能操作JS
渲染引擎不能操作JS,只能操作页面
document.body.appendChild(div1)
是如何改变页面的?
当浏览器发现JS在body里面加个个div1对象,浏览器就会通知渲染引擎在页面里面也新增一个div元素,新增的div元素所有属性都照抄div1对象
data:image/s3,"s3://crabby-images/37c4e/37c4ea9d5ed471830cf908dfad09b992355a7333" alt=""
- 属性同步
标准属性:对标准属性的修改,会被浏览器同步到页面中
data-*属性:同上
非标准属性:对非标准属性的修改,只会停留在JS线程中,不会同步到页面
data:image/s3,"s3://crabby-images/20f92/20f92ff8e3c7229911d2b63aab2fa856903ccb84" alt=""
data:image/s3,"s3://crabby-images/34e80/34e80ade66907835184eba0ffe46976aa59cc798" alt=""
网友评论