Blogger Information
Blog 33
fans 0
comment 0
visits 27903
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
前端 - JS - DOM操作和事件处理
Original
675 people have browsed it

前端 - JS - DOM操作和事件处理

一、DOM操作

  • 节点:html文档中所有内容都是节点

  • 节点树:DOM树

  • 节点类型:1.元素,2.属性,3.文本,6.注释,9.文档,11.文档片断,其余为XML节点

  • 节点集合类型:NodeList(节点列表)和HTMLCollection(HTML集合)

1. 获取节点(单个、多个、相邻节点、兄弟节点、子节点和属性节点)

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <form action="" id="f1">
  10. <input type="text" name="username" id="username">
  11. </form>
  12. <form action="" id="f2">
  13. <input type="text" name="username" id="username">
  14. </form>
  15. <form action="" id="f3">
  16. <input type="text" name="password" id="password">
  17. </form>
  18. <ul class="u">
  19. <li class="uli">列表项1</li>
  20. <li class="uli">列表项2</li>
  21. <li class="uli">列表项3</li>
  22. <li class="uli">列表项4</li>
  23. </ul>
  24. <ol class="o">
  25. <li class="oli">列表项1</li>
  26. <li class="oli">列表项2</li>
  27. <li class="oli">列表项3</li>
  28. <li class="oli">列表项4</li>
  29. </ol>
  30. <script>
  31. //获取文档类型对象
  32. console.log(document.doctype);
  33. //获取html元素
  34. console.log(document.documentElement);
  35. //获取head元素
  36. console.log(document.head);
  37. //获取body元素
  38. console.log(document.body);
  39. //获取title元素
  40. console.log(document.title);
  41. //获取表单元素集合,节点集合类型为HTMLCollection
  42. console.log(document.forms);
  43. // 1. 根据标签获取,返回HTMLCollection对象
  44. console.log(document.getElementsByTagName("ul"));
  45. console.log(document.getElementsByTagName("form"));
  46. // 2. 根据id获取
  47. console.log(document.getElementById("f1"));
  48. // 3. 根据类获取,返回HTMLCollection对象
  49. console.log(document.getElementsByClassName("u"));
  50. console.log(document.getElementsByClassName("oli"));
  51. // 4. 根据name属性获取,返回NodeList对象
  52. console.log(document.getElementsByName("password"));
  53. console.log(document.getElementsByName("username"));
  54. // 5. 根据CSS选择器获取,返回NodeList对象
  55. console.log(document.querySelector(".uli"));
  56. console.log(document.querySelectorAll(".uli"));
  57. //1. 获取前一个相邻节点和获取前一个兄弟节点
  58. console.log(document.getElementsByTagName("ol")[0].previousSibling);
  59. console.log(document.getElementsByTagName("ol")[0].previousElementSibling);
  60. //2. 获取下一个相邻节点和获取下一个兄弟节点
  61. console.log(document.getElementsByTagName("ol")[0].nextSibling);
  62. console.log(document.getElementsByTagName("ol")[0].nextElementSibling);
  63. //3. 获取子节点,返回NodeList对象
  64. console.log(document.getElementsByTagName("ol")[0].childNodes);
  65. //4. 获取子节点,返回HTMLCollection对象
  66. console.log(document.getElementsByTagName("ol")[0].children);
  67. //5. 获取第一个子节点和获取第一个元素节点
  68. console.log(document.getElementsByTagName("ol")[0].firstChild);
  69. console.log(document.getElementsByTagName("ol")[0].firstElementChild);
  70. //5. 获取最后一个子节点和获取最后一个元素节点
  71. console.log(document.getElementsByTagName("ol")[0].lastChild);
  72. console.log(document.getElementsByTagName("ol")[0].lastElementChild);
  73. //获取某个元素的属性节点,返回NamedNodeMap对象
  74. console.log(document.getElementById("f1").attributes);
  75. </script>
  76. </body>
  77. </html>

2. 节点的增删改查

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <form action="" id="f1">
  10. <input type="submit" value="提交" />
  11. </form>
  12. <form action="" id="f2">
  13. <input type="text" name="username" id="username" />
  14. </form>
  15. <form action="" id="f3">
  16. <input type="text" name="password" id="password" />
  17. </form>
  18. <button>重置</button>
  19. <ul class="u">
  20. <li class="uli">列表项1</li>
  21. <li class="uli">列表项2</li>
  22. <li class="uli">列表项3</li>
  23. <li class="uli">列表项4</li>
  24. </ul>
  25. <ol class="o">
  26. <li class="oli">列表项1</li>
  27. <li class="oli">列表项2</li>
  28. <li class="oli">列表项3</li>
  29. <li class="oli">列表项4</li>
  30. </ol>
  31. <script>
  32. //1. 返回节点类型、节点名称
  33. console.log(document.getElementsByClassName("uli")[0].nodeType);
  34. console.log(document.getElementsByClassName("uli")[0].nodeName);
  35. //2. 返回节点的值
  36. //文本节点的内容
  37. console.log(
  38. document.getElementsByTagName("button")[0].childNodes[0].nodeValue
  39. );
  40. //属性节点的值
  41. console.log(
  42. document.getElementsByTagName("input")[0].getAttributeNode("value")
  43. .nodeValue
  44. );
  45. //value属性的值
  46. console.log(document.getElementsByTagName("input")[0].value);
  47. // 3. 创建节点
  48. //创建元素节点
  49. var li = document.createElement("li");
  50. console.log(li);
  51. //创建文本节点
  52. var text = document.createTextNode("列表项5");
  53. console.log(text);
  54. //创建属性节点
  55. var att = document.createAttribute("style");
  56. att.nodeValue = "color:red";
  57. console.log(att);
  58. // 4. 增加子节点
  59. //增加文本节点
  60. li.appendChild(text);
  61. console.log(li);
  62. var ol = document.querySelector(".u");
  63. //增加子节点
  64. ol.appendChild(li);
  65. //增加属性节点
  66. ol.attributes.setNamedItem(att);
  67. // 5. 插入子节点
  68. var li1 = document.createElement("li");
  69. var text1 = document.createTextNode("列表项6");
  70. li1.appendChild(text1);
  71. ol.insertBefore(li1, ol.childNodes[2]);
  72. console.log(ol);
  73. // 6. 删除节点
  74. //删除子节点
  75. ol.removeChild(ol.childNodes[1]);
  76. //删除属性节点
  77. ol.removeAttributeNode(att);
  78. // 7. 修改节点的值
  79. document.getElementsByTagName("input")[0].value = "修改";
  80. // 8. 替换/更新节点
  81. var li2 = document.createElement("li");
  82. var text2 = document.createTextNode("列表项7");
  83. li2.appendChild(text2);
  84. ol.replaceChild(li2, ol.children[0]);
  85. console.log(ol.children);
  86. // 9. 查询是否含有子节点
  87. console.log(ol.hasChildNodes());
  88. //获取子元素
  89. console.log(document.getElementsByTagName("ol")[0].children);
  90. //获取属性节点的值
  91. console.log(
  92. document.getElementsByTagName("input")[0].getAttribute("value")
  93. );
  94. // 3. 创建节点
  95. //创建元素节点
  96. var li = document.createElement("li");
  97. console.log(li);
  98. </script>
  99. </body>
  100. </html>

3. NodeList和HTMLCollection的区别

  • 相同点:都是类数组,都可以通过索引获取元素,索引从0开始,都有length属性

  • 不同点:

  1. 1. 获取方法不同。前者通过querySelectorAll获取的文档节点,后者通过类名和标签获取的HTML元素
  2. 2. 获取节点元素方法不同。前者只能通过索引获取,后者还可通过name和id(namedItem()方法)获取
  3. 3. 前者包含所有的节点类型,后者只包含元素节点

4. DOMTokenList(元素类名列表)

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <ul class="u">
  10. <li class="uli">列表项1</li>
  11. <li class="uli">列表项2</li>
  12. <li class="uli">列表项3</li>
  13. <li class="uli">列表项4</li>
  14. </ul>
  15. <ol class="o">
  16. <li class="oli">列表项1</li>
  17. <li class="oli">列表项2</li>
  18. <li class="oli">列表项3</li>
  19. <li class="oli">列表项4</li>
  20. </ol>
  21. </body>
  22. <script>
  23. //获取类名
  24. console.log(document.getElementsByClassName("u")[0].className);
  25. //获取classList对象
  26. console.log(document.getElementsByClassName("u")[0].classList);
  27. //增加类名
  28. document.getElementsByClassName("u")[0].classList.add("u01");
  29. //删除类名
  30. document.getElementsByClassName("u")[0].classList.remove("u01");
  31. //修改类名
  32. document.getElementsByClassName("u")[0].classList.replace("u", "u01");
  33. </script>
  34. </html>

二、事件处理

1. 添加事件

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <button onclick="alert('hello')">按钮1</button>
  10. <button>按钮2</button>
  11. <button>按钮3</button>
  12. <div class="d1">
  13. <div class="d2">
  14. <div class="d3"></div>
  15. </div>
  16. </div>
  17. </body>
  18. <script>
  19. //添加事件方式1:给html元素绑定事件属性
  20. //添加事件方式2:给html元素添加事件属性
  21. var bth2 = document.querySelectorAll("button")[1];
  22. bth2.onclick = function () {
  23. alert(this.nodeName);
  24. };
  25. //添加事件方式3:监听html元素
  26. var bth3 = document.querySelectorAll("button")[2];
  27. bth3.addEventListener(
  28. "click",
  29. function () {
  30. alert("world");
  31. },
  32. false
  33. );
  34. </script>
  35. </html>

2. 事件派发

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <button>按钮</button>
  10. </body>
  11. <script>
  12. var bth = document.querySelector("button");
  13. bth.addEventListener(
  14. "click",
  15. function () {
  16. alert("hello");
  17. },
  18. false
  19. );
  20. //创建一个事件
  21. var ev = new Event("click");
  22. //向一个目标派发一个事件
  23. bth.dispatchEvent(ev);
  24. </script>
  25. </html>

3. 事件传递(捕获)

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <div class="d1">
  10. <div class="d2">
  11. <div class="d3">
  12. <button>按钮</button>
  13. <div class="d4">
  14. <div class="d5"></div>
  15. </div>
  16. </div>
  17. </div>
  18. </body>
  19. <script>
  20. var d1 = document.getElementsByClassName("d1")[0];
  21. var d2 = document.getElementsByClassName("d2")[0];
  22. var d3 = document.getElementsByClassName("d3")[0];
  23. var d4 = document.getElementsByClassName("d4")[0];
  24. var d5 = document.getElementsByClassName("d5")[0];
  25. //事件捕获
  26. d1.addEventListener(
  27. "click",
  28. function (ev) { console.log('d1') },
  29. true
  30. );
  31. d2.addEventListener(
  32. "click",
  33. function (ev) { console.log('d2') },
  34. true
  35. );
  36. d3.addEventListener(
  37. "click",
  38. function (ev) { console.log('d3') },
  39. true
  40. );
  41. d4.addEventListener(
  42. "click",
  43. function (ev) { console.log('d4') },
  44. true
  45. );
  46. d5.addEventListener(
  47. "click",
  48. function (ev) { console.log('d5') },
  49. true
  50. );
  51. </script>
  52. </html>

4. 事件传递(冒泡)

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <div class="d1">
  10. <div class="d2">
  11. <div class="d3">
  12. <button>按钮</button>
  13. <div class="d4">
  14. <div class="d5"></div>
  15. </div>
  16. </div>
  17. </div>
  18. </body>
  19. <script>
  20. var d1 = document.getElementsByClassName("d1")[0];
  21. var d2 = document.getElementsByClassName("d2")[0];
  22. var d3 = document.getElementsByClassName("d3")[0];
  23. var d4 = document.getElementsByClassName("d4")[0];
  24. var d5 = document.getElementsByClassName("d5")[0];
  25. //事件冒泡
  26. d1.addEventListener(
  27. "click",
  28. function (ev) { console.log('d1') },
  29. false
  30. );
  31. d2.addEventListener(
  32. "click",
  33. function (ev) { console.log('d2') },
  34. false
  35. );
  36. d3.addEventListener(
  37. "click",
  38. function (ev) { console.log('d3') },
  39. false
  40. );
  41. d4.addEventListener(
  42. "click",
  43. function (ev) { console.log('d4') },
  44. false
  45. );
  46. d5.addEventListener(
  47. "click",
  48. function (ev) { console.log('d5') },
  49. false
  50. );
  51. </script>
  52. </html>

4. 事件委托

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <ul>
  10. <li>1</li>
  11. <li>2</li>
  12. <li>3</li>
  13. <li>4</li>
  14. <li>5</li>
  15. </ul>
  16. </body>
  17. <script>
  18. //子元素上的事件会冒泡到父元素上的同名事件上触发
  19. document.querySelector("ul").addEventListener("click", function (ev) {
  20. console.log(ev.target);
  21. });
  22. </script>
  23. </html>

四、课程总结

  • 今天学习了 JavaScript 的DOM操作和事件处理,通过上课认真听讲和认真完成老师布置的作业,使得我对 DOM和事件 的理解和运用更加深入和熟悉。最主要的知识点是明白和掌握了操作DOM和事件处理的特点以及基本用法。
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post