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的元素选择方法是什么?
- getElementById() 通过id查询元素
- getElementsByClassName() 通过类名查询元素
- getElementsByTagName() 通过标签名查询元素
- getElementsByName() 通过name属性查询元素
- 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元素?
<div class="mod-tabs">
<ul>
<li>list1</li>
<li>list2</li>
<li>list3</li>
</ul>
<button class="btn">点我</button>
</div>
所有的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