属性 元素的内容 创建,插入和删除节点 虚拟节点

属性

html元素由一个标签和一组称为属性的名/值对组成。

HTML

表示HTML文档元素的HTMLElement对象定义了读/写属性。映射了元素的HTML属性。HTMLElement定义了通用的HTTP属性。以及事件处理程序的属性。特定的Element子类型为其元素定义了特定的属性。
举个栗子

<!DOCTYPE html>
<html>
<head>
    <title></title>
</head>
<body>
    <img id="myimage" src="./image/1.png" title="图片"/>
    <form>
        <input type="text" name="id"/>
    </form>
</body>
</html>

js如下

var image = document.getElementById("myimage"); // 获取id为myimage的元素
var imagurl = image.src     // 获取该元素的imagurl

控制台输入如下

imagurl
"http://1.198.105.7/image/1.png"

成功获取了img元素的src地址
下面为一个form元素设置表单属性

var f = document.forms[0];  // 获取第一个form元素
f.action = "./submit/"  // 设置提交地址
f.method = "POST";  // 设置提交方式为post提交

设置完成,提交表单

http://1.198.105.7/submit/

链接跳转到上方地址,接着查看浏览器,查看提交的post数据即可查到提交的post数据

ps 不能在头部引入,会出现找不到DOM节点的情况,请在文末引入

获取和设置非标准的HTML属性

现在说的是一个html的属性,即HTMLElemnent对象定义的html的一些属性

Element.getAttribute()

该属性的获取传入属性的属性值。
将会返回一个字符串

image.getAttribute("src")
"./image/1.png"

数据集属性

可以在元素上添加属性,然后能通过js读取其数据
h5在Elemnent对象上定义了dataset属性,该属性指代一个对象,它的各个属性对于去掉前缀的data-属性,因此dataset.x的应该保存为data-x属性的值,如果后方有字符串,将会按照驼峰命名法命名data-jquery-test将会办成dataset。jqueryTest
下面生成一个火花线
html如下所示

<span class="sparkLine" data-ymin="0" data-ymax="10">
    1 1 1 2 2 3 4 5 5 4 3 5 4 3 5 3 6 2 4 5 2 4
</span>
var sparkLines = document.getElementsByClassName("sparkLine");
for (var i = 0; i < sparkLines.length; i++) {
    var dataset = sparkLines[i].dataset;    // 将自定义的属性保存在dataset中
    var ymin = parseFloat(dataset.ymin);    // 将ymin字符转换为浮点数进行存储
    var ymax = parseFloat(dataset.ymax);    // 同理获取最大值
    var data = sparkLines[i].textContent.split(" ").map(parseFloat);    // 获取节点的内容,依照空格进行分割,并将值依次转换为数值
    console.log(data);
}

可以看到控制台已经输出一个数组了。

作为attr节点的属性

一种使用Element的属性的方法。Node类型定义了attributes属性。针对非Element对象任何节点。该属性为null。
获取属性的
举例子

document.body.attributes[0];    // 获取第一个body的第一个属性
document.body.attributes.bgcolor;   // 获取bgcolor属性
document.body.attributes["NOLOAD"]  // 获取元素的onload属性 因为会自动转为大写故因此。

元素的内容

作为HTML的元素内容

以标签作为分隔

<div id="target">This is the element content!</div>
beforebegin     afterbegin              beforeend   afterend

获取内容,上方的是插入元素的内容

nodeList[0].innerHTML
以及
nodeList[0].textContent
该两个方法相同

使用innerHTML可以获取元素的内容
同样也可以使用这个方法进行更改

nodeList[0].innerHTML = "hello word"

将会把页面内容更改为hello word

script元素中的文本

内联的script元素,有一个text属性能来获取它们的文本,该文本存在于树中,但是并不会将其显示出来

作为text节点的元素内容

另一中方法处理元素的内容是当做一个子节点列表。每个子节点可能有它自己的一组子节点。
假设html如下

<span class="sparkLine" data-ymin="0" data-ymax="10">hell<span>o w</span>ord</span>
nodeList[0].innerHTML
"hell<span>o w</span>ord"
nodeList[0].textContent;
"hello word"

上方代码很明显的看到innerHTML会返回其中的HTML代码,包括标签
但是textContent不会,会把所有的内容统统返回

插入元素内容

有两个定义好的api分别是element.insertAdjacentHTML 以及 Element.insertAdjacentText()
这两个元素内容

element.insertAdjacentHTML()

这个会将文本解析为html或者xml,并且将结果插入指定的DOM树的位置。因为它不会重新解析正在使用的元素,因此它不会破坏元素内的现有元素。将会避免额外的序列化步骤,比直接innerHTML将会快很多。

document.getElementById("myimage").insertAdjacentHTML("beforebegin", html)

完成了一次在前方的插入一个div的节点。
此节点插入的html会被html解析器进行解析,如果用户插入请务必进行转义,防止小白攻击法

Element.insertAdjacentText()

这个仅仅是插入文本,建议一般使用这个,将不会产生dom树的解析

var h = document.getElementById("myH2");
h.insertAdjacentText("afterend", "My inserted text");

这样就完成了,一次dom节点的更新
即使插入

h.insertAdjacentText("afterend", "<div></div>")

也不会被dom解析

创建,插入和删除节点

创建节点

创建一个text节点

var newnode = document.createTextNode("hello word")

查看其内容

#text "hello word"

继续,创建一个正常的元素

var newnode = document.createElement("script")

将其插入id为myimage的元素后边

myimage.appendChild(newnode)

插入节点

一旦有了一个新节点可以使用Node方法的appendChild或者insertBefore()将其完成插入。
https://developer.mozilla.org/zh-CN/docs/Web/API/Node/insertBefore
https://developer.mozilla.org/zh-CN/docs/Web/API/Node/appendChild
如果调用插入的方法将文档中的一个节点再次插入,那个节点将会自动从它当前的位置删除并在新的位置重新插入,没有必要显式的删除节点,因为节点已经自动隐式删除了。

删除和替换节点

removeChild()方法重文档树中删除一个节点。该方法不在待删除的节点上调用,而是在其父节点上调用(和名字暗示那样的child)然后将其子节点删除。

n.parentNode.removeChild(n)

将会删除n节点的子节点的n节点
replaceChild()方法删除一个子节点并用一个新的节点取而代之,在父节点上调用该方法。用一个文本字符串来替换节点n

n.parentNode.replaceChild(document.createTextNode("[ REDACTED ]"), n);

一个栗子

// 用一个新的<b>元素替换n节点,并使n成为该元素的子节点
function embolden(n) {
    // 根据参数为字符串而不是节点,将其当做元素的id,进行查询得到节点,如果传入的是节点,直接进行下一步
    if (typeof n == "string") n = document.getElementById(n);
    var parent = n.parentNode;  // 获得n的父节点
    var b = document.createElement("b");    // 创建一个<b>元素
    parent.replaceChild(b, n);  // 进行替换操作
    b.appendChild(n);   // 使得n成为父节点的子节点
};

通过api完成子节点的替换,使用方法,调用一个removeChild以及parentNode完成一次调用

一个虚拟节点

var p = document.createElement("p");
undefined
p;
<p>
container.appendChild(p);
<p>
container
<div>
a;
<body>
a.appendChild(container)
<div>
p;
<p>
p.textContent = "hello word!"
"hello word!"

好啦,页面成功更新,使用虚拟节点拼接完成一个比较完成的树,在将其拼接到body的子节点中,彻底的完成节点操作

DocumentFragment

DocumentFragment 为一种特殊的Node,其作为其他节点的一个临时容器。
它的特殊之处在于它能使得一组节点被当做一个节点看待。

举栗子

倒序排列节点n的子节点

// 倒序排列节点n的子节点
function reverse(n) {
    // 创建一个DocumentFragment 座位临时容器
    var f = document.createDocumentFragment();
    // 从后到前循环子节点,使得每一个子节点移动到临时容器中
    // n的最后一个节点变成f的第一个节点
    // 每次给f添加一个节点该节点会自动从n中删除
    while(n.lastChild) f.appendChild(n.lastChild);  // 添加子节点


    // 最后,把f的所有子节点一次性全部移回n中
    n.appendChild(f);
};

insertAdjacentHTML() 将指定的文本解析为HTML或XML,并将结果节点插入到DOM树中的指定位置。

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

推荐阅读更多精彩内容

  •   DOM(文档对象模型)是针对 HTML 和 XML 文档的一个 API(应用程序编程接口)。   DOM 描绘...
    霜天晓阅读 3,613评论 0 7
  •   DOM 1 级主要定义的是 HTML 和 XML 文档的底层结构。   DOM2 和 DOM3 级则在这个结构...
    霜天晓阅读 1,422评论 1 3
  • 第3章 基本概念 3.1 语法 3.2 关键字和保留字 3.3 变量 3.4 数据类型 5种简单数据类型:Unde...
    RickCole阅读 5,096评论 0 21
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,421评论 1 45
  • 明代张岱云:“人无癖不可与交,以其无深情也,人无疵不可与交,以其无真气也。” 一个人既无癖又无疵,四平八稳,谨小慎...
    风熊花吉阅读 109评论 0 0