JS-十一章:DOM扩展

本文详细介绍了HTML5中新增的DOM操作方法与属性,包括querySelector和querySelectorAll等选择器,以及childElementCount等元素计数属性。同时,探讨了焦点管理、HTMLDocument的变化,如readyStatge和dataset属性,以及innerHTML操作的效率优化技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.扩展方法

1.querySelector('');//方法接收一个css选择符,返回符合的第一个元素,没有则返回null

2.querySelectorAll('');//返回一个NodeList集合

3.getElementsByClassName(' ');//返回NodeList,接收类名

二.扩展的属性

说明:使用这些属性,不必担心空文本节点(空的也存在)

1.childElementCount;//返回元素的个数(不包快文本节点textnode和注释)

2.firstElementChild;//区别firstChild元素,意为第一个子元素(htmlElement类型)

3.lastElementChild;//区别lastChild

4.previousElementSibling;//区别previousSibling;

5.nextElementSibling;//区别nextSibling;

三.焦点管理

1.element.focus();//某元素获得焦点

2.document.hasFocus();//判断页面是否获得焦点,用于判断是否在操作该页面

四.HTMLDocument的HTML五的变化

//新属性

1.document.readyStatge;//loading或者complete//在加载或者加载完成

2.element.dataset;//可以访问自定义的属性

3.element.innerHTML;//元素内的所有文字(按原来的格式输出)//设置这个值相当于重写该元素的内容//注意问题,内容替换指点的元素时,最好移除监听事件先,以防内存泄漏

4.element.innerText;//属性元素内所有的文本内容

5.element.children;//还属性获得一个HTMLCollection集合//和NodeList还是有点区别的

//innerHTML操作属性的效率优化
//低效率版
for (var i=0, len=values.length; i < len; i++){
 ul.innerHTML += "<li>" + values[i] + "</li>"; //要避免这种频繁操作!!

//高效率版
var itemsHtml = "";
for (var i=0, len=values.length; i < len; i++){
 itemsHtml += "<li>" + values[i] + "</li>";
}
ul.innerHTML = itemsHtml; 

疑惑:

//div嵌套一个div,为什么div的NodeList会有三个元素

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值