探讨JS中获取元素属性8大方法

开发 前端
今天想聊聊在Web前端开发中经常用到的技术:获取元素属性的一系列方法【innerHTML、outerHTML、innerText 、outerText、value、text()、html(),val()】。

今天想聊聊在Web前端开发中经常用到的技术:获取元素属性的一系列方法【innerHTML、outerHTML、innerText 、outerText、value、text()、html(),val()】。

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

首先我们需要把它们归类下:

  • innerHTML、outerHTML、innerText 、outerText、value 属于原生javascript的方法。
  • text()、html(),val()属于jQuery中的方法。

[[285109]]

1. innerHTML 属性

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

  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> 

 

对于上面的元素来说,它的 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> 

 

2. outerHTML 属性

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

  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> 

 

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

使用 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); 

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

 

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

语法:

  1. node.replaceChild(newnode,oldnode) 

3. 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> 

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

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

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

  1. div.innerText = "Hello world!"

执行这行代码后,页面的 HTML 代码就会变成如下所示:

  1. <div id="content">Hello world!</div> 

设置 innerText 属性移除了先前存在的所有子节点,完全改变了 DOM 树。

设置 innerText 永远只会生成当前节点的一个子文本节点,而为了确保只生成一个字文本节点,就必须要对文本进行 HTML 编码。利用这一点,可以通过 innerText 属性过滤掉 HTML 标签。方法是将 innerText 设置等于 innerText,这样就可以去掉所有 HTML 标签,比如:

  1. divdiv.innerText = div.innerText; 

执行这行代码后,就用原来的文本内容替换了容器元素中的所有内容(包括子节点,因而也就去掉了 HTML 标签)。举个栗子:

  1. <label id="lab">请输入北京今天空气质量:<input id="aqi-input" type="text"></label> 

输出:

JS中获取元素属性的8大方法

4. 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 的元素。此后,该元素就从文档中被删除,无法访问。

5. value 属性

属性可设置或返回密码域的默认值。获取文本框的值。

6. text():设置或者获取所选元素的文本内容

(1) 无参text():

取得所有匹配元素的内容。结果是由所有匹配元素包含的文本内容组合起来的文本。返回的是一个String。

JS中获取元素属性的8大方法

(2) 有参text(val):

设置所有匹配元素的文本内容,与 html() 类似, 但将编码 HTML (将 "<" 和 ">" 替换成相应的HTML实体).返回一个jquery对象。

JS中获取元素属性的8大方法

7. html():设置或者获取所选元素的内容(包括html标记)

(1) 无参html():

取得第一个匹配元素的html内容。这个函数不能用于XML文档。但可以用于XHTML文档,返回的是一个String。

JS中获取元素属性的8大方法

(2) 有参html(val):

设置每一个匹配元素的html内容。这个函数不能用于XML文档。但可以用于XHTML文档。返回一个jquery对象。

JS中获取元素属性的8大方法

8. val()方法

主要用于获取表单元素的值如input, select 和 textarea。当在一个空集合上调用,它返回undefined;

(1) 无参 val() :

获取匹配的元素集合中第一个元素的当前值。例子:

HTML代码:

  1. <input type="text" value="你好啊"> 
  2. <input type="text" value="啊哈哈哈"> 
  3. <input type="text" value="嘻嘻嘻嘻"> 

控制台输出:

JS中获取元素属性的8大方法

(2) 有参val(val):

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

JS中获取元素属性的8大方法

 

责任编辑:赵宁宁 来源: Web前端之家
相关推荐

2009-07-06 13:18:35

Servlet方法

2010-08-09 14:54:58

Flex全屏

2010-07-29 13:41:57

Flex性能优化

2022-04-24 13:54:23

元宇宙虚拟土地VR

2015-06-10 14:28:34

数据中心数据中心优化

2014-04-18 09:06:25

2011-03-24 14:26:59

2009-09-15 15:51:52

2019-04-18 14:28:40

Linux系统服务命令

2018-11-12 13:45:05

Hadoop攻击互联网

2015-06-08 14:08:11

2015-08-13 10:42:49

.NET空白字符串

2015-10-29 11:55:30

.NET空白字符串方法

2011-09-28 13:38:53

CA云计算云安全

2011-09-28 16:21:21

云安全企业

2011-06-14 18:54:25

网站流量

2009-01-11 10:25:00

局域网共享上网

2011-05-16 10:30:02

2009-09-15 16:53:50

2022-10-09 15:32:05

数据分析大数据运营
点赞
收藏

51CTO技术栈公众号