JS 对自定义属性的规范 及 JS 父子节点书写规范

简介: H5 对自定义属性的规范 及 JS 父子节点书写规范

H5 规定自定义属性规范

H5 规定自定义属性应以 data- 开头作为属性名并赋值,并对这种自定义的属性添加了一种获取的方法: element.dataset


首先我们输出一下 dataset,看看 dataset 是什么,可以看到直接输出dataset,输出结果为一个对象 集合,所以dataset 是一个包含了所有 data- 开头的自定义属性的集合


<div data-index="1" data-name="jack"></div>

    <script>

        var div=document.querySelector('div');

        console.log(div.dataset);

    </script>


单独输出有两种形式:dataset.XXX 以及 dataset[XXX]


<div data-index="1" data-name="jack"></div>

    <script>

        var div=document.querySelector('div');

        console.log(div.dataset.index);

        console.log(div.dataset['index']);

    </script>


对于较长的属性命名,如:data-index-first ,获取时需要采用驼峰命名法,dataset.indexFirst


父节点

在获取元素时我们可以利用DOM提供的一系列方法获取,但是这些方法过于繁琐,不简练。所以我们学习节点操作,页面中所有内容都是节点,有文档节点,元素节点,属性节点等,我们主要针对研究的是元素节点


节点(node)拥有 节点类型(nodeType),节点名称(nodeName),节点值(nodeValue)


父节点:

parentNode:得到的是最近的父级节点,找不到的话返回 null


<div class="father">

       <div class="son"></div>

   </div>

   <script>

       var son=document.querySelector('.son');

       console.log(son.parentNode);

   </script>


子节点

有父节点,也有子节点,例如在列表中获取一堆 li 标签就显得很便捷


子节点:

childNodes:可以看出输出结果为9个,但是明明只有四个元素,那剩下的五个是什么呢?可以看到每个 li 标签换行时有回车,回车算文本节点,也就是这个方法会把元素节点和文本节点都输出出来


<ul class="father">

           <li></li>

           <li></li>

           <li></li>

           <li></li>

       </ul>

   <script>

       var father=document.querySelector('.father');

       console.log(father.childNodes);

   </script>



对此也有解决办法,使用 nodeType 得到属性值,元素节点属性值为 1,文本节点属性值为 3,属性节点的属性值为 2,只要判断是否为1即可


<ul class="father">

           <li></li>

           <li></li>

           <li></li>

           <li></li>

       </ul>

   <script>

       var father=document.querySelector('.father');

       for(var i=0;i<father.childNodes.length;i++){

           if(father.childNodes[i].nodeType==1){

               console.log(father.childNodes[i]);

           }

       }

   </script>


但这种方法太繁琐,不使用这种,有另一种方法


更简便的方法:element.children




<ul class="father">

           <li></li>

           <li></li>

           <li></li>

           <li></li>

       </ul>

   <script>

       var father=document.querySelector('.father');

     console.log(father.children);

   </script>



相关文章
|
2月前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
2月前
|
监控 JavaScript 前端开发
确定使用 `defer` 属性还是 `async` 属性来异步加载 JavaScript
【10月更文挑战第24天】选择使用 `defer` 属性还是 `async` 属性来异步加载 JavaScript 是一个需要综合考虑多个因素的决策。需要根据脚本之间的依赖关系、页面加载性能要求、脚本的功能和重要性等因素来进行权衡。在实际应用中,需要通过测试和验证来确定最适合的加载方式,以提供更好的用户体验和页面性能。
|
2月前
|
监控 JavaScript 前端开发
使用 `defer` 属性异步加载 JavaScript
【10月更文挑战第24天】使用 `defer` 属性异步加载 JavaScript 是一种有效的提高页面性能和用户体验的方法。通过合理设置 `defer` 属性,可以在不影响页面渲染的情况下异步加载脚本,并确保脚本的执行顺序。在实际应用中,需要根据具体情况选择合适的加载方式,并注意处理可能出现的问题,以确保页面能够正常加载和执行。
|
3月前
|
移动开发 JavaScript 前端开发
原生js如何获取dom元素的自定义属性
原生js如何获取dom元素的自定义属性
99 4
|
3月前
|
缓存 JavaScript 前端开发
探索Vue.js中的计算属性与侦听器
【10月更文挑战第5天】探索Vue.js中的计算属性与侦听器
35 1
|
4月前
|
JavaScript 前端开发 索引
JavaScript HTML DOM 节点列表
JavaScript HTML DOM 节点列表
29 5
|
4月前
|
JavaScript 前端开发
JavaScript HTML DOM 元素 (节点)
JavaScript HTML DOM 元素 (节点)
37 2
|
3月前
|
存储 JavaScript 前端开发
js中map属性
js中map属性
29 0
|
3月前
|
缓存 JavaScript 前端开发
深入理解Vue.js中的计算属性与侦听属性
【10月更文挑战第5天】深入理解Vue.js中的计算属性与侦听属性
46 0
|
3月前
|
缓存 JavaScript 前端开发
探索Vue.js中的计算属性与侦听器:深入理解与实践
【10月更文挑战第5天】探索Vue.js中的计算属性与侦听器:深入理解与实践
35 0