给大家聊下js中获取元素属性的逆天大法,胆小慎入,切记切记!!!

innerHTML、outerHTML、innerText 、outerText、value、text()、html(),val()

这些方法,大家应该用过,如果让你说出它们的一些区别和联系,能答得上来吗?接下来让我们一起来温故下。

innerHTML、outerHTML、innerText 、outerText、value 属于原生javascript的方法。

text()、html(),val()属于jQuery中的方法。

第一式:innerHTML 属性

innerHTML属性返回与调用元素的所有子节点(包括元素、注释和文本节点)对应的 HTML 标记。在写模式下,innerHTML 会根据指定的值创建新的 DOM 树,然后用这个 DOM 树完全替换调用元素原先的所有子节点。下面是一个例子:

 <div id="content">
<p>This is a <strong>paragraph</strong> with a list following it.</p>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
</div>

对于上面的<div>元素来说,它的 innerHTML 属性会返回如下字符串。

 <p>This is a <strong>paragraph</strong> with a list following it.</p>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>

第二式:outerHTML 属性

outerHTML 返回调用它的元素及所有子节点的 HTML 标签。在写模式下,outerHTML 会根据指定的 HTML 字符串创建新的 DOM 子树完全替换调用元素。

下面是一个例子:

 <div id="content">
<p>This is a <strong>paragraph</strong> with a list following it.</p>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
</div>

如果在<div>元素上调用 outerHTML,会返回与上面相同的代码,包括<div>本身。

使用 outerHTML 属性以下面这种方式设置值:

 div.outerHTML = "<p>This is a paragraph.</p>";

这行代码完成的操作与下面这些 DOM 脚本代码一样:

 var p = document.createElement("p");
p.appendChild(document.createTextNode("This is a paragraph."));
div.parentNode.replaceChild(p, div);

结果,就是新创建的<p>元素会取代 DOM 树中的<div>元素。

replaceChild() 方法用新节点替换某个子节点。

语法:

 node.replaceChild(newnode,oldnode)

第三式:innerText 属性

通过 innerText 属性可以操作元素中包含的所有文本内容,包括子文档树中的文本。在通过 innerText 读取值时,它会按照由浅入深的顺序,将子文档树中的所有文本拼接起来。在通过 innerText 写入值时,结果会删除元素的所有子节点,插入包含相应文本值的文本节点。

下面是一个例子:

 <div id="content">
<p>This is a <strong>paragraph</strong> with a list following it.</p>
<ul>
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
</div>

对于这个例子中的 <div> 元素而言,其中 innerText 属性会返回下列字符串:

 This is a paragraph with a list following it.
Item 1
Item 2
Item 3

使用 innerText 属性设置这个<div>元素内容,则只需一行代码:

 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 不只是替换调用它的元素的子节点,而是会替换整个元素(包括子节点)。

比如:

 div.outerText = "Hello world!";

这行代码实际上相当于如下两行代码:

 var text = document.createTextNode("Hello world!");
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代码:

 <input type="text" value="你好啊">
<input type="text" value="啊哈哈哈">
<input type="text" value="嘻嘻嘻嘻">

控制台输出:

2     有参val(val):

设置每一个匹配元素的值。返回一个jquery对象。

总结

事已至此,你是否了解明白了很多?

切记此功法不可外穿,否则会惹杀身之祸,切记,切记,切记!!!

最新文章

  1. BZOJ 1717: [Usaco2006 Dec]Milk Patterns 产奶的模式 [后缀数组]
  2. Spring学习笔记之三----基于Annotation的Spring IOC配置
  3. VS2012智能提示消失的解决方法
  4. C#生成验证码
  5. fidder 使用教程
  6. .net使用cefsharp开源库开发chrome浏览器(一)
  7. [Effective JavaScript 笔记]第39条:不要重用父类的属性名
  8. Sniffer抓包教程
  9. 学习《Javascript权威指南》的第二章笔记
  10. windbg 调试技巧
  11. JAVA EE获取浏览器和操作系统信息
  12. Python入门(一)数据类型、循环语句
  13. [leetcode]256. Paint House粉刷房子(三色可选)
  14. Crypto++应用:非对称加密RSA
  15. 纯干货,Spring-data-jpa详解(转)
  16. django -- model中只有Field类型的数据才能成为数据库中的列
  17. 以太坊(Ethereum) - 节点时间未同步和区块同步失败案例分析
  18. Android-Java-进程与线程
  19. Unity3D — — UGUI之RectTransform
  20. ubuntu下 mysql安装以后无法登陆的的解决方法((ERROR 1698 (28000): Access denied for user &#39;root&#39;@&#39;localhost&#39;))

热门文章

  1. markdown公式转为知乎格式
  2. SQL SERVER数据库内,需要序列号进行排序时,排序方法
  3. 并发新构件之CyclicBarrier
  4. 使用java语言实现一个动态数组(详解)(数据结构)
  5. 初识域渗透利器Empire
  6. 不安分的管家——Jenkins
  7. (22)ASP.NET Core EF创建模型(索引、备用键、继承、支持字段)
  8. Chrome 浏览器垃圾回收机制与内存泄漏分析
  9. Spring Boot入门(二):获取配置文件值
  10. java的数制转换(详解,全!)