dom操作

所有节点共有的属性:

 

nodeType: 返回的是数字,每一个数字代表一种节点类型。

 

nodeName:对于元素节点,返回的是元素的标签名。

 

nodeValue:对于元素节点,返回的始终是null。对于文本节点返回的是文本内容(可以直接赋值设置)。

节点关系:

 

childNodes:返回的是所有的子节点,数据结构类似于数组的NodeList对象。可以像数组一样使用索引取值。

 

children:返回的是所有的元素元素的元素子节点。

 

childElementCount:返回子元素的个数。

 

parentNode:返回的是节点的父节点。

 

previousSibling: 节点的前一个同级节点。

 

previousElementSibling:指向前一个同辈元素。

 

nextSibling: 节点的下一个同级节点。

 

nextElementSibling:指向后一个同辈元素。

 

firstChild: 节点的第一个子节点。

 

firstElementChild:指向第一个子元素。

 

lastChild: 节点的最后一个子节点。

 

lastElementChild:指向最后一个子元素。

 

 

元素操作:

 

appendChild:向元素的childNodes的NodeList最后面添加上一个元素。如果元素是已经是文档的一部分,那只是换位置,不会增加相同的元素。返回的是添加的那个元素。

 

insertBefore:将元素的childNodes的NodeList中插入一个节点,接受两个参数,要被插入的节点,和作为参考位置的节点。将插入的节点放在参考位置节点的前面。新节点被返回。

 

replaceChild:将元素的childNodes的NodeList中的某个元素替换。接受两个参数,要插入的节点,和要被替换的节点。这个方法返回要被替换的节点。

 

removeChild:将元素的childNodes的NodeList的某个元素删除。这个方法接受一个参数,即要被删除的元素。返回的是值是被删除的节点。

 

cloneNode:将元素进行复制,这个方法接受一个Boolean值,如果是true,复制元素包括子节点。否则只是复制元素本身。复制的元素需要通过以上的方法才能在文档中显示。不会复制js的事件处理程序。

 

Document:

 

document:是HTMLDocument(继承自Document)的实例,表示整个html页面。

 

document.documentElement:取到的是html元素。

 

document.body:取到的是body元素。

 

document.title: 取到的是文档的标题,可以直接给它赋值来修改标题。

 

元素属性:

 

HTMLElement:所有的元素都通过这个类型或者它的子类型来表示,它继承自Element并添加了一些属性。添加了这么几个属性:id、title、lang(元素内部的语言代码)、dir(语言的方向,从左到右ltr或者从右到左rtl。这里影响的是对齐方式)、className。这些属性所有的元素都都存在。并且可以通过赋值直接修改这些属性。

 

元素的特性:所有公认的属性都可以直接通过元素获取。自定义的不行。一般自定的属性都通过getAttribute方法。设置自定义属性也需通过setAttribute,否则不生效。

 

 

attributes:这个属性包含了元素的所有特性,每个节点的nodeName就是特性的名称。nodeValue就是就是特性的值。

 

getNamedItem(name):返回nodeName属性等于name的节点。

 

removeNamedItem(name):从列表中删除nodeName属性等于name的节点。会返回删除的节点。

 

setNamedItem(node):向列表添加节点,以节点的nodeName属性为索引。

 

item(pos):返回位于数字pos位置处的节点。

 

 

获取某个元素的文本可以这样获取:document.getElementById(‘a’).childNodes[0].nodeValue。直接赋值可以修改其内容

 

通过data-xx设置的属性可以直接通过该元素的dataset属性访问到,也可以直接通过这个dataset属性给元素增加data-xx格式的属性。

 

元素查询:

 

querySelector: 接收css选择符,返回与该模式匹配的第一个元素。可以用在元素上,作用于该元素的后代元素。

 

querySelectorAll: 接收css选择符,但是返回的是一个nodeList的实例的快照,即不会动态的随着增加删除元素而改变。

 

操作class:

 

classList:返回给定元素的所有class,它内部的方法可以操作className。

 

add:将给定的字符串添加到列表中。

 

contains:表示列表中是否存在给定的值,存在返回true,否则返回false。

 

remove:从列表中删除给定的字符串。

 

toggle:如果列表存在给定的值,那就删除,否则的话添加。

 

 

焦点管理:

 

document.activeElement:这个属性始终会引用dom中当前获得了焦点的元素。

 

document.hasFocus:这个方法用于确定文档是否获得了焦点。

 

focus: 给某个元素获取到焦点。

 

 

滚动到指定元素:

 

scrollIntoView:这个方法可以使用任何元素调用,调用以后页面滚动到指定元素。如果传入了true或者不传,将滚动到元素的最顶部与页面对齐,如果传入false元素会尽可能的全部出现在页面中。

 

scrollIntoViewIfNeeded:只有在视口中不可见的情况下,才滚动浏览器窗口或者容器元素,否则什么也不做,,如果传入true,则尽量将元素显示在视口中部。(兼容性不是很好,专有扩展)

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值