给你们聊下js中获取元素属性的逆天大法,胆小慎入,切记切记!!!javascript
innerHTML、outerHTML、innerText 、outerText、value、text()、html(),val()
这些方法,你们应该用过,若是让你说出它们的一些区别和联系,能答得上来吗?接下来让咱们一块儿来温故下。html
innerHTML、outerHTML、innerText 、outerText、value 属于原生javascript的方法。java
text()、html(),val()属于jQuery中的方法。node
第一式:innerHTML 属性jquery
innerHTML属性返回与调用元素的全部子节点(包括元素、注释和文本节点)对应的 HTML 标记。在写模式下,innerHTML 会根据指定的值建立新的 DOM 树,而后用这个 DOM 树彻底替换调用元素原先的全部子节点。下面是一个例子:app
1 <div id="content"> 2 <p>This is a <strong>paragraph</strong> with a list following it.</p> 3 <ul> 4 <li>Item 1</li> 5 <li>Item 2</li> 6 <li>Item 3</li> 7 </ul> 8 </div>
对于上面的<div>元素来讲,它的 innerHTML 属性会返回以下字符串。函数
1 <p>This is a <strong>paragraph</strong> with a list following it.</p> 2 <ul> 3 <li>Item 1</li> 4 <li>Item 2</li> 5 <li>Item 3</li> 6 </ul>
第二式:outerHTML 属性编码
outerHTML 返回调用它的元素及全部子节点的 HTML 标签。在写模式下,outerHTML 会根据指定的 HTML 字符串建立新的 DOM 子树彻底替换调用元素。spa
下面是一个例子:3d
1 <div id="content"> 2 <p>This is a <strong>paragraph</strong> with a list following it.</p> 3 <ul> 4 <li>Item 1</li> 5 <li>Item 2</li> 6 <li>Item 3</li> 7 </ul> 8 </div>
若是在<div>元素上调用 outerHTML,会返回与上面相同的代码,包括<div>自己。
使用 outerHTML 属性如下面这种方式设置值:
1 div.outerHTML = "<p>This is a paragraph.</p>";
这行代码完成的操做与下面这些 DOM 脚本代码同样:
1 var p = document.createElement("p"); 2 p.appendChild(document.createTextNode("This is a paragraph.")); 3 div.parentNode.replaceChild(p, div);
结果,就是新建立的<p>元素会取代 DOM 树中的<div>元素。
replaceChild() 方法用新节点替换某个子节点。
语法:
1 node.replaceChild(newnode,oldnode)
第三式:innerText 属性
经过 innerText 属性能够操做元素中包含的全部文本内容,包括子文档树中的文本。在经过 innerText 读取值时,它会按照由浅入深的顺序,将子文档树中的全部文本拼接起来。在经过 innerText 写入值时,结果会删除元素的全部子节点,插入包含相应文本值的文本节点。
下面是一个例子:
1 <div id="content"> 2 <p>This is a <strong>paragraph</strong> with a list following it.</p> 3 <ul> 4 <li>Item 1</li> 5 <li>Item 2</li> 6 <li>Item 3</li> 7 </ul> 8 </div>
对于这个例子中的 <div> 元素而言,其中 innerText 属性会返回下列字符串:
1 This is a paragraph with a list following it. 2 Item 1 3 Item 2 4 Item 3
使用 innerText 属性设置这个<div>元素内容,则只需一行代码:
1 div.innerText = "Hello world!";
执行这行代码后,页面的 HTML 代码就会变成以下所示:
<div id="content">Hello world!</div>
设置 innerText 属性移除了先前存在的全部子节点,彻底改变了 DOM 树。
设置 innerText 永远只会生成当前节点的一个子文本节点,而为了确保只生成一个字文本节点,就必需要对文本进行 HTML 编码。利用这一点,能够经过 innerText 属性过滤掉 HTML 标签。方法是将 innerText 设置等于 innerText,这样就能够去掉全部 HTML 标签,
好比:
div.innerText = div.innerText;
执行这行代码后,就用原来的文本内容替换了容器元素中的全部内容(包括子节点,于是也就去掉了 HTML 标签)。
举个例子:
<label id="lab">请输入北京今天空气质量:<input id="aqi-input" type="text"></label>
输出:
第四式:outerText 属性
除了做用范围扩大到了包含 调用它的节点以外,outerText 与innerText 基本上没有多大区别。在读取文本值时,outerText 与 innerText 的结果彻底同样。但在写模式下,outerText 就彻底不一样了:outerText 不仅是替换调用它的元素的子节点,而是会替换整个元素(包括子节点)。
好比:
1 div.outerText = "Hello world!";
这行代码实际上至关于以下两行代码:
1 var text = document.createTextNode("Hello world!"); 2 div.parentNode.replaceChild(text,div);
本质上,新的文本节点会彻底取代调用 outerText 的元素。此后,该元素就从文档中被删除,没法访问。
第五式:value 属性
属性可设置或返回密码域的默认值。获取文本框的值。
第六式:text():设置或者获取所选元素的文本内容
1 无参text():
取得全部匹配元素的内容。结果是由全部匹配元素包含的文本内容组合起来的文本。返回的是一个String。
2 有参text(val):
设置全部匹配元素的文本内容,与 html() 相似, 但将编码 HTML (将 "<" 和 ">" 替换成相应的HTML实体).返回一个jquery对象。
第七式:html():设置或者获取所选元素的内容(包括html标记)
1 无参html():
取得第一个匹配元素的html内容。这个函数不能用于XML文档。但能够用于XHTML文档,返回的是一个String。
2 有参html(val):
设置每个匹配元素的html内容。这个函数不能用于XML文档。但能够用于XHTML文档。返回一个jquery对象。
第八式:val()方法
主要用于获取表单元素的值如input, select 和 textarea。当在一个空集合上调用,它返回undefined;
1 无参 val() :
获取匹配的元素集合中第一个元素的当前值。
例子:
HTML代码:
1 <input type="text" value="你好啊"> 2 <input type="text" value="啊哈哈哈"> 3 <input type="text" value="嘻嘻嘻嘻">
控制台输出:
2 有参val(val):
设置每个匹配元素的值。返回一个jquery对象。
事已至此,你是否了解明白了不少?
切记此功法不可外穿,不然会惹杀身之祸,切记,切记,切记!!!