DOM操作

dom对象的innerText和innerHTML有什么区别?

  • innerHTML:在读模式下,innerHTML返回调用元素的所有子节点(包括元素、注释和文本节点)对应的HTML标记。在写模式下,innerHTML会根据指定的值创建新的DOM树,然后用这个DOM树完全替换调用元素原先的所有子节点。
  • innerText:再通过innerText读取值时,它会按照由浅入深的顺序,将子文档树中的所有文本拼接起来。在通过innerText写入值时,结果会删除元素的所有子节点,插入包含相应文本值的节点。在设置该属性的同时,也对文本中存在的HTML语法字符(<>&引号)进行了编码(与操作文本节点nodeValue属性类似)。

elem.children和elem.childNodes的区别?

  • childNodes 该属性保存着一个NodeList对象,这是一个类数组对象,独特之处在于能够基于DOM结构动态执行查询结果,因此DOM结构的变化能够随时反应出来。
  • children 只包含元素类型(nodeType) 为1(Node.ELEMENT_NODE)的子节点,而childNodes包含所有类型的子节点,除此之外没有什么区别。
  • 对arguments对象使用Array.prototype.slice()方法可以将其转化为数组。同样的方法也可以将NodeList对象转化为数组。(IE8+)
    var arrayOfNodes = Array.prototype.slice.call(someNode.childNodes,0);

查询元素有几种常见的方法?ES5的元素选择方法是什么?

  1. getElementById() 通过id查询元素
  2. getElementsByClassName() 通过类名查询元素
  3. getElementsByTagName() 通过标签名查询元素
  4. getElementsByName() 通过name属性查询元素
  5. ES5的方法:querySelector()/querySelectorAll() 通过类似css选择器的写法查询元素。而其底层实现类似于一组元素的快照,而非不断对文档进行搜索的动态查询。这样实现可以避免使用NodeList对象通常会引起的大多数性能问题。

如何创建一个元素?如何给元素设置属性?如何删除属性

  • 创建元素: document.createElement()
  • 设置属性: setAttribute('属性名', '内容')。有因为所有特性都是属性,所以也可以直接给属性赋值来设置element.className = 'mamba'
  • 删除属性:removeAttribute()

如何给页面元素添加子元素?如何删除页面元素下的子元素?

这些方法都由其父元素调用

  • 添加子元素:
    appendChild()把要插入的这个节点引用作为返回值返回
    insetBefore(newNode, oneNode)把要插入的这个节点引用作为返回值返回,即newNode
  • 删除子元素: removeChild() 返回被删除的节点
  • 替换子元素: replaceChild(newNode, oneNode)返回被替换掉的节点

element.classList有哪些方法?如何判断一个元素的 class 列表中是包含某个 class?如何添加一个class?如何删除一个class?

  • Element.classList 是一个只读属性,返回一个元素的类属性的实时 DOMTokenList集合。拥有length属性
  • add( String [, String] )
    添加指定的类值。如果这些类已经存在于元素的属性中,那么它们将被忽略。
  • remove( String [,String] )
    删除指定的类值。
  • toggle ( String [, force] )
    当只有一个参数时: 如果类存在,则删除它并返回false,如果不存在,则添加它并返回true。
    当存在第二个参数时:如果第二个参数的计算结果为true,则添加指定的类值,如果计算结果为false,则删除它
  • contains( String )
    检查元素的类属性中是否存在指定的类值。

如何选中如下代码所有的li元素? 如何选中btn元素?

  • list1
  • list2
  • list3

所有的li元素:
1.var items = document.getElementsByTagName('li');
2.var items = document.querySelectorAll('.mod-tabs li');
选中btn元素:
1.var items = document.getElementsByClassName('btn');
2.var items = document.querySelector('.btn')

1
1
1
1
11
1
1
1
1
1

你可能感兴趣的:(DOM操作)