博客列表 >类数组与DOM元素API即DOM元素的遍历

类数组与DOM元素API即DOM元素的遍历

三九三伏
三九三伏原创
2022年07月27日 19:10:43304浏览

一、类数组

纯数组

  1. ...
  2. <script>
  3. const arr = ['red', 'green', 'blue'];
  4. console.log(arr);
  5. // 数组也是对象
  6. console.log(arr instanceof Object);
  7. </script>
  8. ...

类数组,”类”是类似的类。

  1. ...
  2. <script>
  3. ...
  4. const light = {
  5. 0:'red',
  6. 1:'green',
  7. 2:'blue',
  8. length:3,
  9. };
  10. console.log(light);
  11. </script>
  12. ...

访问方法也可以是一样的

  1. ...
  2. <script>
  3. ...
  4. console.log(arr[0], arr[1], arr[2]);
  5. console.log(light[0], light[1], light[2]);
  6. ...
  7. </script>
  8. ...

类数组在DOM中经常被用到。

二、获取dom元素的API及使用场景

1. querySelectorAll

得到一组元素并可针对性修改。

  1. ...
  2. <script>
  3. ...
  4. const items = document.querySelectorAll('.list .item');
  5. console.log(items);
  6. // items是一个NodeList,节点列表对象,有自己的方法。
  7. console.log(items.keys());
  8. items.forEach(v => (v.style.backgroundColor = 'yellow'));
  9. ...
  10. </script>
  11. ...

2. qureySelector

获取一组元素的第一个

  1. ...
  2. <script>
  3. ...
  4. const lis = document.querySelector('.item');
  5. console.log(lis);
  6. lis.style.backgroundColor = 'violet';
  7. ...
  8. </script>
  9. ...

3. 快捷方式

  1. ...
  2. <script>
  3. ...
  4. // 传统方式
  5. console.log(document.querySelector('body'));
  6. console.log(document.querySelector('head'));
  7. console.log(document.querySelector('title').textContent);
  8. // 快捷方式
  9. console.log(document.body);
  10. console.log(document.head);
  11. console.log(document.title);
  12. ...
  13. </script>
  14. ...

三、优雅的获取form表单元素与控件的值

  1. ...
  2. <form action="login.php" method="post" id="login">
  3. <fieldset class="login">
  4. <legend>用户登录</legend>
  5. <label for="email">邮箱:</label>
  6. <input type="email" name="" id="email" value="admin@php.cn" autofocus>
  7. <label for="password">密码:</label>
  8. <input type="password" name="" id="password" value="123456">
  9. <button>提交</button>
  10. </fieldset>
  11. </form>
  12. <script>
  13. ...
  14. // 表单:form.id
  15. console.log(document.forms.login);
  16. // 表单控件:input.name
  17. console.log(document.forms.login.email);
  18. // 表单控件的值:input.name.value
  19. console.log(document.forms.login.email.value);
  20. ...
  21. </script>
  22. ...

四、DOM元素的遍历与常用API

节点类型包括:
window:全局对象
document:文档对象,即HTML文件
element:元素对象,ul/li/table…
text:文本对象,item1,item2…

  1. <ul class="list">
  2. <li class="item">item1</li>
  3. <li class="item">item2</li>
  4. <li class="item">item3</li>
  5. <li class="item">item4</li>
  6. <li class="item">item5</li>
  7. <li class="item">item6</li>
  8. </ul>
  9. ...
  10. <script>
  11. ...
  12. let ul = document.querySelector('.list');
  13. console.log(ul.children);//类数组
  14. // 转成真数组
  15. console.log(Array.from(ul.children));
  16. // 更优雅的方法
  17. console.log([...ul.children]);
  18. [...ul.children].forEach(li =>(li.style.color = 'blue'));
  19. [...ul.children][0].style.backgroundColor = 'yellow';
  20. ul.firstElementChild.style.backgroundColor = 'red';
  21. // 第二个
  22. ul.firstElementChild.nextElementSibling.style.backgroundColor = 'green';
  23. // 最后一个
  24. ul.lastElementChild.style.backgroundColor = 'red';
  25. // 最后一个的前一个
  26. ul.lastElementChild.previousElementSibling.style.backgroundColor = 'pink';
  27. // 父节点
  28. ul.lastElementChild.parentElement.style.border = '2px solid red';
  29. ...
  30. </script>
  31. ...

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议