通过css类/选择器选取元素 文档结构和遍历 元素树的文档

通过css类选取元素

html所有的元素拥有class属性,该属性会对元素进行分组,标识为某一组。
js中使用className属性来保存HTML的class的属性值

var NodeList = document.getElementById("first")
close.log(NodeList.class)

尽管如此,js还定义了一个方法,即一个getElementsByClassName(),是基于class属性值中的标识符来选取成组的文档元素
还有一个类似的getElementsByTagName()的方法也是获取一个组,返回的是一组的内容即NodeList。返回的是类数组。
一个使用getElementsByClassName()的例子

// 查找其class属性值中包含warning的所有元素
var warnings = document.getElementsByClassName("warning");
// 查找以log命名并且含有error和fatal类的元素的所有后代
var log = document.getElementById("log");
var fatal = log.getElementByClassName("fatal error");   // 先获取id为log,在获取class为fatal error的元素

一个兼容,浏览器根据!doctype来进行选择怪异模式,和标准模式的,怪异模式是为了向后兼容而存在的,标准模式不是(兼容以及不太重要了,但是还要知道一点,这是ie8的问题,但愿再过几年直接win7也没有了)

通过css选择器选择元素

css样式表可以进行选择,这里仅仅是一些常见的css选择器

#nav // id = nav 的元素
div // 选择div元素
.warning // 选择class属性为waring的元素

// 基于属性值选取元素
p[lang="fr"]    // 所有语言为fr的元素
*[name="x"] // 所有包含name="x"的属性的元素

// 将选择器进行组合使用
span.fatal.error    // 选择class中包含fatal和error的span元素
span[lang="fr"].warning // 所有使用法语,并且class中包含warning的span元素

// 选择器指定文档结构
#log span   // id 为log元素的后代元素中的所有的span元素
#log > span // id 为log元素的子元素中所有的span元素
body>h1:first-child // <body>的子元素中的第一个<h1>元素

// 选择器组合选择多个或者组合元素
div, #log   // 所有的div元素,以及id为log的元素属于和关系

// 正则选择器
a[src^="https"] // 选择src属性为https开头的
a[src$=".pdf"]  // 匹配src属性为.pdf结尾的元素
a[src*="ming"]  // 匹配src中包含ming的元素

h5定义了一些选择api用来通过js来选择元素

document.querySelector("title")

选择title元素

document.querySelectorAll("title")

会返回一个类数组的 节点列表

document.querySelector(":first-line")

选择一个伪元素,在css中匹配了节点一部分,而不是实际元素。
其中querySelector只会返回匹配的第一个结果,querySelectorAll将会返回全部结果,返回一个类数组。

document.querySelector(":link")

返回一个页面上未访问的连接

document.querySelectorAll(":visited")

选择一个已经访问过的,用来获取用户在该页面的一部分的历史记录

document.all[]

已经废弃,不在使用,所以不学习

文档结构和遍历

一旦从文档中选取了一个元素,将会需要查找文档与之在结构上相关的部分,(即,父元素,子元素,兄弟元素)。温带在概念上为节点对象树。浏览器定义了一个api将会对元素对象树进行遍历

作为节点树的文档

Document对象,以及Element对象和文档中表示文本的Text对象都为Node对象,Node对象定义了一下重要的属性。

parentNode

获取该节点的父节点

childNode

只读类型数组对象(NodeList对象),它是该节点的子节点的实时表示

firstChild, lastChild

该节点的子节点中的第一个和最后一个

nextSibling,previousSibling

该节点的兄弟节点中的前一个和下一个

nodeType

该节点的类型

一些类 继承(基类,父类,超类),派生类,子类
这里以c++为栗子 :基类,父类,超类,指被继承的类,派生类,子类指继承于基类的类,在C++中冒号表示继承,入classA:public:B 表示派生类A从基类B继承而来。派生类包含基类的所有成员,还包括自身的特有成员,由于继承关系的存在,派生类和派生类对象访问基类中的成员就像访问自己的成员一样。可以直接使用,但是派生类,仍旧无法访问基类中的私有成员。C++派生类可以同时从多个基类继承,java不允许多重继承,当继承多个基类的时候,使用,运算符将基类进行分开。

Element

Element是一个通用的基类,所有的Document都继承自Element
例如

<p>

属于一个由Element基类继承的Document的一个节点

text节点

文字内容,即匿名文字所成的节点。

Comment节点

属于注释的节点

<!-- 这是注释内容 -->

Document 节点

一个已经加载好的网页,并通过入口来操作网页的内容

DocumentType节点

一个声明节点

DocumentFragment 节点

表示一个没有父级文件的最小文档对象。它被当做一个轻量版的 Document 使用

nodeValue

text节点或者Comment节点文本内容

nodeName

元素的标签名,以大写输出

一个栗子

<!DOCTYPE html>
<html>
<head>
    <title></title>
</head>
<body>
hello word
</body>
</html>

控制台输入

document.childNodes[1].childNodes[2].childNode[0]

返回

#text

表示

<body>之前的导致换行符

该html

<!DOCTYPE html><html><head><title></title></head>
<body>hello word</body></html>

继续重新加载,重新输入

document.childNodes[1].childNodes[1]
#text

继续去掉唯一的换行符

<!DOCTYPE html><html><head><title></title></head><body>hello word</body></html>

继续在控制台输入

document.childNodes[1].childNodes[1]
<body style>​…​</body>​

返回body
说明是换行符的问题导致
https://stackoverflow.com/questions/45614337/what-causes-childnodes-to-return-text-instead-of-div
https://stackoverflow.com/questions/21357004/what-are-html-dom-text-elements

作为元素树的文档

将文档看成Element对象树,忽视部分文档,text和comment文档(回车,空格,以及注释节点)

Element的children属性

第一部分是Element(通用基类)的children属性,类似于childNodes属于一个NodeList对象,不同的是children列表只包含Element对象,text和Comment节点没有children属性,任何的Element的parentNode(父节点)都是另一个Element,或者是树根的Document节点

Element的属性

firstElementChild,lastElementChild
类似firstChild和lastChild,只代表子Element
nextElementSibling,previousElementSibling
类似的nextSibling和previousSibling 代表兄弟节点
childElementCount
子元素的数量,和children。length的值相等

博客

www.iming.info

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容

  •   DOM(文档对象模型)是针对 HTML 和 XML 文档的一个 API(应用程序编程接口)。   DOM 描绘...
    霜天晓阅读 3,613评论 0 7
  • 第3章 基本概念 3.1 语法 3.2 关键字和保留字 3.3 变量 3.4 数据类型 5种简单数据类型:Unde...
    RickCole阅读 5,096评论 0 21
  •   DOM 1 级主要定义的是 HTML 和 XML 文档的底层结构。   DOM2 和 DOM3 级则在这个结构...
    霜天晓阅读 1,422评论 1 3
  • 最近发现同事在设计类接口的时候喜欢用UML图,以前对这方面了解一点,只是没有怎么使用过。了解一下UML的基本原理,...
    勇往直前888阅读 740评论 0 2
  • 情人节快乐,希望我们一直相爱,从少年到暮年,老公,我爱你!
    Helen_燕子阅读 187评论 0 0