前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >【收藏】JavaScript DOM操作简易速查手册

【收藏】JavaScript DOM操作简易速查手册

原创
作者头像
毛瑞
修改于 2019-05-06 01:43:22
修改于 2019-05-06 01:43:22
1.2K0
举报
文章被收录于专栏:三十课三十课

1 概述

1.1 前言

本文中简要罗列了JavaScript操作Dom的基本方法,其中包括元素查询、文档结构遍历、属性及内容操作、创建节点、插入节点及删除节点等内容。虽然JQuery更便利,但我还是喜欢用原生的API

2 文档元素选取

2.1 ID选择器

通过ID选取元素是最简单和常用的选取元素的方法,ID选择器性能优于其它选择器。

代码语言:txt
AI代码解释
复制
var title = document.getElementById("title");

ID不存在,返回 null

查看示例程序

2.2 名称选择器

基于name属性的值选取元素区别于ID选择器。其一,name属性值 不是必须唯一,多个元素可能有同样的名称;其二,name属性只在少数HTML元素中有效,包括表单、表单元素、iframeimg 元素。

代码语言:txt
AI代码解释
复制
var sports = document.getElementsByName("sports");

查看示例程序

2.3 标签选择器

利用HTML元素的标签名称选取指定类型的元素。

代码语言:txt
AI代码解释
复制
var h1 = document.getElementsByTagName("h1");

查看示例程序

2.4 类选择器

通过HTML的 class 属性值选择元素。

代码语言:txt
AI代码解释
复制
var title = document.getElementsByClassName("title");

查看示例程序

2.5 CSS单元素选择器

通过CSS样式表选择器的强大语法,来选择元素。返回第一个匹配的元素。

代码语言:txt
AI代码解释
复制
var title = document.querySelector("#title");   // CSS ID选择
var h1 = document.querySelector("h1");     //选取第一个h1元素

查看示例程序

2.6 CSS多元素选择器

这是最强大的终极选择器

代码语言:txt
AI代码解释
复制
var h1s = document.querySelectorAll("h1");    //返回所有h1标签元素

查看示例程序

3 DOM遍历

3.1 节点相关

3.1.1 父节点-parentNode

返回父节点,如果 document 对象调用则返回 null

代码语言:txt
AI代码解释
复制
var parent = node.parentNode;

查看示例程序

3.1.2 子节点-childNodes

返回所有子节点,即NodeList对象。

代码语言:txt
AI代码解释
复制
var children = node.childNodes;

查看示例程序

3.1.3 首子节点-firstChild

返回第一个子节点。

代码语言:txt
AI代码解释
复制
var first = node.firstChild;

查看示例程序

3.1.4 尾子节点-lastChild

返回最后一个子节点。

代码语言:txt
AI代码解释
复制
var last = node.lastChild;

查看示例程序

3.1.5 下一兄弟节点-nextSibling

返回下一个兄弟节点。

代码语言:txt
AI代码解释
复制
var next = node.nextSibling;

查看示例程序

3.1.6 前一兄弟节点-previousSibling

返回前一个兄弟节点。

代码语言:txt
AI代码解释
复制
var previous = node.previousSibling;

查看示例程序

3.1.7 节点类型-nodeType

返回节点类型的数字表示。

  • 1代表 Element 节点
  • 3代表 Text 节点
  • 8代表 Comment 节点
  • 9代表 Document 节点
  • 11代表 DocumentFragment 节点

查看示例程序

3.1.8 节点值-nodeValue

返回 Text 节点 或 Comment 节点的值。

代码语言:txt
AI代码解释
复制
var value = node.nodeValue;

查看示例程序

3.1.9 节点名-nodeName

返回元素的标签名,以大写形式表示。

代码语言:txt
AI代码解释
复制
var name = node.nodeName;

查看示例程序

3.2 元素相关

3.2.1 子元素-children

返回所有子元素。

代码语言:txt
AI代码解释
复制
var children = node.children;

查看示例程序

3.2.2 首子元素-firstElementChild

元素是节点的一种。

返回所有子元素中的第一个。

代码语言:txt
AI代码解释
复制
var first = node.firstElementChild;

查看示例程序

3.2.3 尾子元素-lastElementChild

返回所有子元素中的最后一个。

代码语言:txt
AI代码解释
复制
var last= node.lastElementChild;

查看示例程序

3.2.4 下一兄弟元素-nextElementSibling

返回下一个兄弟元素。

代码语言:txt
AI代码解释
复制
var next = node.nextElementSibling;

查看示例程序

3.2.5 前一兄弟元素-previousElementSibling

返回前一兄弟元素。

代码语言:txt
AI代码解释
复制
var previous = node.previousElementSibling;

查看示例程序

3.2.6 子元素数量

返回子元素的数量。

代码语言:txt
AI代码解释
复制
var count = node.childElementCount;

查看示例程序

4 属性

4.1 标准属性

表示HTML文档元素的 HTMLElement 对象定义了读/写属性,它们对应于元素的HTML属性。HTMLElement 定义了通用的HTML属性,包括id、lang、dir、事件处理程序 onclick 及表单相关属性等。

代码语言:txt
AI代码解释
复制
form.action = "http://30ke.cn";
form.method = "post";

查看示例程序

4.2 非标准属性

4.2.1 获取属性值-getAttribute

返回非标准的HTML属性的值。

代码语言:txt
AI代码解释
复制
var width = img.getAttribute("width");

查看示例程序

4.2.2 属性值设置-setAttribute

设置非标准的HTML属性的值。

代码语言:txt
AI代码解释
复制
img.setAttribute("width","400px");

查看示例程序

4.2.3 属性存在检测-hasAttribute

返回布尔值,用来检测属性是否存在。

代码语言:txt
AI代码解释
复制
var result = img.hasAttribute("width");

查看示例程序

4.2.4 删除属性-removeAttribute

删除某一属性。

代码语言:txt
AI代码解释
复制
img.removeAttribute("width");

查看示例程序

4.3 数据集属性-dataset

HTML5文档中,任意以 data- 为前缀的小写的属性名字都是合法的。这些 “数据集属性” 定义了一种标准的、附加额外数据的方法。

代码语言:txt
AI代码解释
复制
var x = img.dataset.x;

查看示例程序

4.4 元素属性-attributes

Node节点定义了 attributes 属性,针对 Element 对象,attributes 是元素所有属性的类数组对象。

代码语言:txt
AI代码解释
复制
var attributes = img.attributes;

索引 attributes 对象得到的值是 Attr 对象。Attr 的 name 和 value 返回该属性的名字和值。

查看示例程序

5 元素内容

5.1 元素内容-innerHTML

innerHTML 属性以字符串形式返回这个元素的内容。也可以用来替换元素当前内容。

代码语言:txt
AI代码解释
复制
var innerHTML = parent.innerHTML;     // 获取节点的内容
parent.innerHTML = "<h1>三十课</h1>";  //替换节点的内容

查看示例程序

5.2 元素及内容-outerHTML

outerHTML 属性以字符串形式返回这个元素及内容。也可以用来替换当前元素及内容。

代码语言:txt
AI代码解释
复制
var outerHTML = parent.outerHTML;     // 获取节点及内容
parent.outerHTML= "<h1>三十课</h1>";  //替换节点及其内容

查看示例程序

5.3 纯文本元素内容-textContent

查询或替换纯文本元素内容的标准方法是用Node的textContent属性来实现。在IE中,可以用 Element 的 innerText 属性来代替。

代码语言:txt
AI代码解释
复制
console.log(title.textContent);
title.textContent = "三十课2";

查看示例程序

6 创建节点

6.1 创建元素节点-createElement

使用 document 对象的 createElement() 方法创建新的 Element节点。

代码语言:txt
AI代码解释
复制
var h1 = document.createElement("h1");

查看示例程序

6.2 创建文本节点-createTextNode

创建纯文本节点。

代码语言:txt
AI代码解释
复制
var txt = document.createTextNode("三十课");

查看示例程序

6.3 创建文档片段-createDocumentFragment

使用文档片段通常会带来更好的性能。因为文档片段存在于内存中,并不在DOM树中,所以将子元素插入到文档片段时不会引起页面回流(对元素位置和几何上的计算)。

代码语言:txt
AI代码解释
复制
var fragment = document.createDocumentFragment();

查看示例程序

6.4 创建注释节点-createComment

创建注释节点不经常使用。

代码语言:txt
AI代码解释
复制
var comment = document.createComment("Created by 毛瑞");

查看示例程序

6.5 节点克隆-cloneNode

通过复制已存在的节点来创建新的文档节点。传参数 true 表示深克隆,false表示浅复制。

代码语言:txt
AI代码解释
复制
var title2 = title.cloneNode(true);

查看示例程序

7 插入节点

7.1 插入子节点-appendChild

在指定元素上插入子节点,并使其成为该节点的最后一个子节点。

代码语言:txt
AI代码解释
复制
parent.appendChild(h2);  

查看示例程序

7.2 节点前插入-insertBefore

  • 在父节点上调用本方法
  • 第一参数表示待插入的节点
  • 第二参数是父节点中已经存在的子节点,新节点插入到该节点的前面
代码语言:txt
AI代码解释
复制
parent.insertBefore(h1,h2);   // h1插入到h2之前。

查看示例程序

8 删除和替换

8.1 删除子节点-removeChild

  • 在父节点上调用
  • 参数是待删除的节点
代码语言:txt
AI代码解释
复制
parent.removeChild(h2);

查看示例程序

8.2 替换子节点-replaceChild

  • 在父节点上调用
  • 第一个参数是新节点
  • 第二个参数是需要替换的节点
代码语言:txt
AI代码解释
复制
parent.replaceChild(h2n , h2);  

查看示例程序

9 结尾

9.1 结语

本人知识水平有限,在汇编的过程中时有错误发生,如发现请不吝指正!多谢。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
javascript之DOM操作
http://www.cnblogs.com/kissdodog/archive/2012/12/25/2833213.html
bear_fish
2018/09/19
5470
再谈BOM和DOM(3):DOM节点操作-元素样式修改及DOM内容增删改查
className:返回节点样式,可以设置 className="demo1 class2"
周陆军
2021/07/13
1.2K0
dom操作
var div = document.getElementById(‘id名’);//返回是一个,不是数组 var div = document.getElementsByTagName(‘标签名’);//返回数组 (实时) var div = document.getElementsByClassName(‘class名’);//(带s的都是数组) var div = document.getElementsByName(‘name’);//name名 var div = quarySelector();//css选择器 选择一个 里面放’id’,‘class’… var div - quarySelectorAll();//css选择器 选择一个(静态的,不实时。用途受局限)
微醺
2019/01/17
7020
前端学习(47)~DOM简介和DOM操作
DOM:Document Object Model,文档对象模型。DOM 为文档提供了结构化表示,并定义了如何通过脚本来访问文档结构。目的其实就是为了能让js操作html元素而制定的一个规范。
Vincent-yuan
2020/03/19
1.8K0
JavaScript DOM基础
DOM(Document Object Model)即文档对象模型,针对HTML和XML文档的API(应用程序接口)。 一.DOM介绍 DOM中的三个字母,D(文档)可以理解为整个Web加载的网页文档;O(对象)可以理解为类似window对象之类的东西,可以调用属性和方法,这里我们说的是document对象;M(模型)可以理解为网页文档的树型结构。 DOM有三个等级,分别是DOM1、DOM2、DOM3,并且DOM1在1998年10月成为W3C标准。DOM1所支持的浏览器包括IE6+、Firefox、Safa
汤高
2018/01/11
1.4K0
JavaScript的理解记录(5)
    1、Document Object Model(DOM):是表示和操作HTML和XML文档内容的基础API;其中几个重要的类有:Document和Element,Text,这三个也是Node的其中几个子类; 
JQ实验室
2022/02/09
1.5K0
一文解读JavaScript中的文档对象(DOM)
相信做网站对JavaScript再熟悉不过了,它是一门脚本语言,不同于Python的是,它是一门浏览器脚本语言,而Python则是服务器脚本语言,我们不光要会Python,还要会JavaScript,因为它对做网页方面是有很大作用的。
前端皮皮
2021/09/14
7490
一文解读JavaScript中的文档对象(DOM)
【前端基础篇】JavaScript之DOM介绍
WebAPI 就包含了 DOM + BOM. 这个是 W3C 组织规定的. (和制定 ECMAScript 标准的大佬们不是一伙人).
半截诗
2024/10/09
1660
【前端基础篇】JavaScript之DOM介绍
JavaScript——DOM基础
文档对象模型(Document Object Model),简称DOM,是W3C组织推荐的处理可扩展标记语言(HTML或者XML)的标准接口。
岳泽以
2022/10/26
6.6K0
JavaScript——DOM基础
JavaScript DOM(二)
通过上文可知获取元素可以来利用 DOM 提供的方法来获取元素,如 getElementById、querySelector 等方法,但是也可以利用节点关系来获取元素
赤蓝紫
2023/01/01
6480
JavaScript DOM(二)
javaScript操作DOM
文档对象模型(Document Object Model, DOM),在控制面板中用window.document获取
河马嘴不大
2022/12/24
6330
javaScript操作DOM
DOM--文档对象模型
DOM中文名文档对象模型,英文名Document Object Model,我们简称为DOM,是针对html和xml文档的一种API,将html以一种树状结构呈现出来,可以更直观去研究文档结构,我们将这种树状文档结构称为--DOM树,或者节点树,一样的概念
子舒
2022/06/09
1.2K0
DOM--文档对象模型
JavaScript中的Dom和Bom
当创建好一个页面并加载到浏览器时,DOM就悄然而生,它会把网页文档转换为一个文档对象,主要功能是处理网页内容。
用户7293182
2022/01/20
9390
JavaScript中的Dom和Bom
属性 元素的内容 创建,插入和删除节点 虚拟节点
表示HTML文档元素的HTMLElement对象定义了读/写属性。映射了元素的HTML属性。HTMLElement定义了通用的HTTP属性。以及事件处理程序的属性。特定的Element子类型为其元素定义了特定的属性。
mySoul
2018/08/07
2.5K0
回到基础:什么是DOM及DOM操作?
文本主要介绍文档对象模型(DOM),了解什么是DOM操作,以及如何使用砶 DOM API 与 JS 中的 Web 页面进行交互。
前端小智@大迁世界
2022/06/15
9820
DOM(文档对象模型):理解网页结构与内容操作的关键技术
DOM的编程接口由一组标准属性和方法定义。属性通常用于描述节点的特征,而方法通常用于执行与节点相关的操作。
小万哥
2024/03/29
1530
DOM(文档对象模型):理解网页结构与内容操作的关键技术
前端架构师之10_JavaScript_DOM
第1级DOM(DOM Level 1,或DOM1)。为XML和HTML文档中的元素、节点、属性等提供了必备的属性和方法。结合了Netscape及微软公司开发的DHTML(动态HTML)思想。
张哥编程
2024/12/13
1480
13个需要知道的方法:使用 JavaScript 来操作 DOM
DOM 或文档对象模型是 web 页面上所有对象的根。它表示文档的结构,并将页面连接到编程语言。它的结构是一个逻辑树。每个分支结束于一个节点,每个节点包含子节点、对象。DOM API非常庞大,在本文中,咱们只讨论比较常用有有用的那些API。
前端小智@大迁世界
2022/06/15
6970
DOM操作
1.概述 1.1DOM DOM是JavaScript操作网页的接口,全称为“文档对象模型”(Document Object Model)。文档对象模型 (DOM) 是HTML和XML文档的编程接口。它给文档(结构树)提供了一个结构化的表述并且定义了一种方式—程序可以对结构树进行访问,以改变文档的结构,样式和内容。 浏览器会根据DOM模型,将结构化文档(比如HTML和XML)解析成一系列的节点,再由这些节点组成一个树状结构(DOM Tree)。所有的节点和最终的树状结构,都有规范的对外接口。所以,DOM可以理
小胖
2018/06/27
1.9K0
DOM操作
在学习了JavaScript之后,我们会想,如何使用JavaScript来操纵HTML呢。
摸鱼的G
2023/02/22
4160
DOM操作
相关推荐
javascript之DOM操作
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档