DOM操作

作者: liushaung | 来源:发表于2017-08-06 21:00 被阅读0次

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

  • innerHtml:Element.innerHTML 属性设置或获取描述元素后代的HTML语句。
  • innerText:Node.innerText 是一个表示一个节点及其后代的“渲染”文本内容的属性。
  • 区别:innerHtml会获取一个元素的所有后代元素的Html代码,而innerText只会获取所有后代元素的文本内容

Element.children和Element.childNodes的区别?

  • Element.children 返回一个HTMLCollection , 包含当前元素的所有子元素节点(Element Node)的有序列表集合。如果没有子元素节点那么该集合的长度为0;返回的列表是动态的,这意味着它会随着DOM树的变化自动更新自身。
  • Element.childNodes 返回一个NodeList, 包含当前元素的所有子节点的有序列表,子节点类型包括:元素节点(Element Node),注释节点(Comment Node),文本节点(Text Node)等,没有子节点时,该集合的长度为0;
  • 共性:都为只读属性,不能通过为该属性赋值来改变父节点的子节点内容
  • 区别:NodeList集合主要是Node节点的集合,而HTMLCollection集合主要是Element元素节点的集合。Node节点共有12种,Element元素节点只是其中一种。

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

  • document.getElementById():返回一个匹配特定 ID的元素.
  • document.getElementsByClassName():返回一个类似数组的对象,包含了所有指定 class 名称的子元素。你也可以在任意元素上调用getElementsByClassName() 方法,它将返回的是以当前元素为根节点,所有指定class名称的子元素。
  • document.getElementsByTagName():返回一个动态的包含所有指定标签名的元素的HTML集合HTMLCollection。返回的列表是动态的,这意味着它会随着DOM树的变化自动更新自身。
  • ES5选择方法:
    • document.querySelector():返回文档中匹配指定的选择器组的第一个元素(兼容IE8及以上浏览器)。
    • document.querySelectorAll(): 返回与指定的选择器组匹配的文档中的元素列表。返回的对象是 NodeList(兼容IE8及以上浏览器) 。

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

  • document.createElement():创建一个由tagNamey指定的HTML元素。
  • element.setAttribute():设置指定元素上的一个属性值。
  • element.removeAttribute(): 从指定的元素中删除一个属性。
  • element.getAttribute():返回元素上一个指定的属性值。如果指定的属性不存在,则返回 null 或 "" (空字符串)。

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

  • Node.appendChild():将一个节点添加到指定父节点的子节点列表末尾。
  • Node.insertBefore():在当前节点的某个子节点之前再插入一个子节点。
  • Node.removeChild():从DOM中删除一个子节点。返回删除的节点。
  • Node.replaceChild():用指定的节点替换当前节点的一个子节点,并返回被替换掉的节点。

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

  • Element.classList 是一个只读属性,返回一个元素的类属性的实时 DOMTokenList集合(兼容ie10及以上浏览器)。方法:
    • add():添加指定的类值。如果这些类已经存在于元素的属性中,那么它们将被忽略。
    • remove():删除指定的类值。
    • item():按集合中的索引返回类值。
    • toggle():当只有一个参数时:切换 class value; 即如果类存在,则删除它并返回false,如果不存在,则添加它并返回true。
    • contains():检查元素的类属性中是否存在指定的类值。
  • 如果要兼容低版本浏览器可以使用:Element.className,获取并设置指定元素的class属性的值。

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

    <div class="mod-tabs">
        <ul>
                <li>list1</li>
                <li>list2</li>
                <li>list3</li>
        </ul>
        <button class="btn">点我</button>
    </div>
    var li = document.querySelectorAll('.mod-tabs li') // 获取所有li元素
    var btn = document.querySelector('.btn') // 获取btn元素

相关文章

网友评论

    本文标题:DOM操作

    本文链接:https://www.haomeiwen.com/subject/yijnlxtx.html