更新DOM

拿到一个DOM节点后,我们可以对它进行更新。

可以直接修改节点的文本,方法有两种:

一种是修改innerHTML属性,这个方式非常强大,不但可以修改一个DOM节点的文本内容,还可以直接通过HTML片段修改DOM节点内部的子树:

  1. // 获取<p id="p-id">...</p>
  2. var p = document.getElementById('p-id');
  3. // 设置文本为abc:
  4. p.innerHTML = 'ABC'; // <p id="p-id">ABC</p>
  5. // 设置HTML:
  6. p.innerHTML = 'ABC <span style="color:red">RED</span> XYZ';
  7. // <p>...</p>的内部结构已修改

innerHTML时要注意,是否需要写入HTML。如果写入的字符串是通过网络拿到了,要注意对字符编码来避免XSS攻击。

第二种是修改innerTexttextContent属性,这样可以自动对字符串进行HTML编码,保证无法设置任何HTML标签:

  1. // 获取<p id="p-id">...</p>
  2. var p = document.getElementById('p-id');
  3. // 设置文本:
  4. p.innerText = '<script>alert("Hi")</script>';
  5. // HTML被自动编码,无法设置一个<script>节点:
  6. // <p id="p-id">&lt;script&gt;alert("Hi")&lt;/script&gt;</p>

两者的区别在于读取属性时,innerText不返回隐藏元素的文本,而textContent返回所有文本。另外注意IE<9不支持textContent

修改CSS也是经常需要的操作。DOM节点的style属性对应所有的CSS,可以直接获取或设置。因为CSS允许font-size这样的名称,但它并非JavaScript有效的属性名,所以需要在JavaScript中改写为驼峰式命名fontSize

  1. // 获取<p id="p-id">...</p>
  2. var p = document.getElementById('p-id');
  3. // 设置CSS:
  4. p.style.color = '#ff0000';
  5. p.style.fontSize = '20px';
  6. p.style.paddingTop = '2em';

练习

有如下的HTML结构:

javascript

Java

  1. <!-- HTML结构 -->
  2. <div id="test-div">
  3. <p id="test-js">javascript</p>
  4. <p>Java</p>
  5. </div>

请尝试获取指定节点并修改:

  1. 'use strict';
  2. // 获取<p>javascript</p>节点:
  3. var js = ???;
  4. // 修改文本为JavaScript:
  5. // TODO:
  6. // 修改CSS为: color: #ff0000, font-weight: bold
  7. // TODO:
  8. // 测试:
  9. if (js && js.parentNode && js.parentNode.id === 'test-div' && js.id === 'test-js') {
  10. if (js.innerText === 'JavaScript') {
  11. if (js.style && js.style.fontWeight === 'bold' && (js.style.color === 'red' || js.style.color === '#ff0000' || js.style.color === '#f00' || js.style.color === 'rgb(255, 0, 0)')) {
  12. alert('测试通过!');
  13. } else {
  14. alert('CSS样式测试失败!');
  15. }
  16. } else {
  17. alert('文本测试失败!');
  18. }
  19. } else {
  20. alert('节点测试失败!');
  21. }

原文: https://wizardforcel.gitbooks.io/liaoxuefeng/content/js/34.html