17-第十七章 DOM文档对象模型

DOM(Document Object Model)文档树对象模型

一、节点属性

1、childNodes \ children

Ele.childNodes ————————–子节点集合
元素.childNodes : 只读 属性 子节点列表集合
标准下: 包含了文本和元素类型的节点,也会包含非法嵌套的子节点
非标准下:只包含元素类型的节点,ie7 以下不会包含非法嵌套子节点 (返回元素)

childNodes 只包含一级子节点,不包含后辈孙级
ele.children 获取第一级子元素,集合是动态的。 没有兼容问题(重点记忆)

nodeType : 只读 属性 当前元素的节点类型 共12

  • 元素节点: 1
  • 属性节点: 2
    wrap.attributes[0].nodeType
  • 文本节点: 3

节点类型 命名常量

节点类型 命名常量 中文
1 element_node 元素节点
2 attribute_node 属性节点
3 text_node 文本节点
4 cdata_section_node
5 entity_reference_node
6 entity_node
7 processing_instruction_node
8 comment_node 注释节点
9 document_node 文档节点
10 document_type_node 文档类型节点
11 document_fragment_node 文段片段节点
12 notation_node 符号节点

nodeName 节点名称 (大写)

元素节点属性

ele.tagName元素标签名称 (大写)

有关属性节点操作

获取obj.getAttributeNode() 方法获取指定的属性节点。
创建document.createAttribute(name) 创建拥有指定名称的属性节点,并返回新的 Attr 对象。
添加obj.setAttributeNode(attr, value)方法向元素中添加指定的属性节
点。
删除removeAttribute(attr) 方法删除元素中指定的属性节点

1、firstChild \ firstElementChild 第一个子节点

ele.firstChild : 只读 属性
标准下firstChild 会包含文本类型的节点
非标准下:只包含元素节点

ele.firstElementChild : 只读 属性 标准下获取第一个元素类型的子节点
非标准下:无

2、lastChild \ lastElementChild 最后一个子节点

兼容性同上

3、nextSibling 下一个兄弟节点 /'sɪblɪŋ/ 兄弟

nextElementSibling 下一个兄弟元素节点
兼容性同上

4、previousSibling 上一个兄弟节点 /'priːvɪəs/ 前一个

previousElementSibling 上一个兄弟元素节点
兼容性同上

5、parentNode 获取父节点 没有兼容问题 (重点记忆)
6、offsetParent 最近定位父级(重点记忆)
7、childElementCount 子元素节点个数

元素类型子节点数量,等同于 children.length

二、创建节点

1、document.createElement('tagName') 创建元素节点

innerHTML += 添加元素的问题,原本子元素没有了,不是原本的元素了
ele.innerHTML += 的时候要注意:innerTHML 拿到的是一个字符串,绑定事件只能绑定在元素节点上
赋值可能会出现覆盖

2、创建文档片段
document.createDocumentFragment()

3、document.createTextNode(str) 创建文本节点

4、 element.cloneNode()
参数
true 克隆元素及后代不会克隆属性及事件,
false 克隆本元素

三、元素节点操作

1、parent.insertBefore(newNode, node) 在已有元素前插入

插入子元素 ,在指定的子元素前面插入

        var insertedNode = parentNode .insertBefore(newNode,eferenceNode);
  • insertedNode 正在插入的节点,即 newNode
  • parentNode 新插入节点的父节点。
  • newNode 要插入的节点。
  • referenceNodenewNode 插入之前的节点。
    如果 referenceNodenullnewNode 则插入子节点列表的末尾。
2、parent.appendChild(new) 在已有元素后插入 (没有兼容问题)

往一个元素里面去添加节点,追加到该对象下的所有子元素的最后面
插入子元素,在指定的子元素前面插入
例子:留言板插入内容

3、parent.removeChild(节点)删除一个节点

删除 DOM 元素

4、parent.replaceChild(newNode, oldNode)替换节点

换元素,把旧的节点换成新的节点

ele.innerTHML += 和 ele.appendChild 方法区别在于

ele.innerHTML 会出现覆盖行为,
ele.appendChild 方法不是覆盖,是追加,不会出现覆盖行为

HTML

    <div id="father">
        <div class='son'></div>
    </div>

CSS

        const father = document.getElementById('father');

        let p = document.createElement('p'); // 标签
        let a = document.createElement('a'); // 标签

        p.innerText = '这是P的内容';
        a.innerText = '这是A的内容';

        p.onclick = function () {
            p.style.color = 'yellow'
        }

        // 创建文档片段
        const dom1 = document.createDocumentFragment();

        // 往文档片段追加标签
        dom1.append(p);
        dom1.append(a);

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

推荐阅读更多精彩内容

  •   DOM(文档对象模型)是针对 HTML 和 XML 文档的一个 API(应用程序编程接口)。   DOM 描绘...
    霜天晓阅读 3,601评论 0 7
  • 一、基本概念 1.1、DOM DOM是JS操作网页的接口,全称为“文档对象模型”(Document Object ...
    周花花啊阅读 3,130评论 0 6
  •   DOM 1 级主要定义的是 HTML 和 XML 文档的底层结构。   DOM2 和 DOM3 级则在这个结构...
    霜天晓阅读 1,398评论 1 3
  • 基本概念 DOM DOM 是 JavaScript 操作网页的接口,全称为“文档对象模型”(Document Ob...
    许先生__阅读 857评论 0 1
  • 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法。DOM 将H...
    闪电西兰花阅读 347评论 0 0