DOM操作

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元素
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 什么是DOM??? DOM(Document Object Model 文档对象模型)是针对HTML和XML文档的...
    荧惑3_3阅读 5,274评论 0 1
  • 基本介绍 文档对象模型 (DOM) 是HTML和XML文档的编程接口。它给文档(结构树)提供了一个结构化的表述并且...
    草鞋弟阅读 3,430评论 0 0
  • 题目1: dom对象的innerText和innerHTML有什么区别? innerText是一个可写属性,返回元...
    QQQQQCY阅读 1,553评论 0 0
  • dom对象的innerText和innerHTML有什么区别? Element.innerText属性返回该元素包...
    饥人谷_全阅读 2,738评论 0 0
  • 带一卷书,走十里路,选一清净地,看天,听鸟。倦时和身在草,我在梦里寻梦。我曾觉得,人生对谁都是一条寂寞的路,要有一...
    DinoF阅读 3,169评论 0 0

友情链接更多精彩内容