• 自定义属性操作


    1.1 获取属性值

        <div id="demo" index="1" class="nav"></div>
       <script>
           var div = document.querySelector('div');
           // 1. 获取元素的属性值
           // (1) element.属性
           console.log(div.id);
           //(2) element.getAttribute('属性') get得到获取 attribute 属性的意思 我们程序员自己添加的属性我们称为自定义属性 index
           console.log(div.getAttribute('id'));
           console.log(div.getAttribute('index'));
    </script>

     

    1.2. 设置属性值

            // 2. 设置元素属性值
           // (1) element.属性= '值'
           div.id = 'test';
           div.className = 'navs';
           // (2) element.setAttribute('属性', '值'); 主要针对于自定义属性
           div.setAttribute('index', 2);
           div.setAttribute('class', 'footer'); // class 特殊 这里面写的就是 class 不是 className

     

    1.3. 移除属性

    element . removeAttribute ( '属性') ;

            // 3 移除属性 removeAttribute(属性)    
           div.removeAttribute('index');

     

    1.4. 案例:tab栏

    当鼠标点击上面相应的选项卡(tab) ,下面内容跟随变化

     

        <script>
           // 获取元素
           var tab_list = document.querySelector('.tab_list');
           var lis = tab_list.querySelectorAll('li');
           var items = document.querySelectorAll('.item');
           // for循环,给选项卡绑定点击事件
           for (var i = 0; i < lis.length; i++) {
               // 开始给5个小li 设置索引号
               lis[i].setAttribute('index', i);
               lis[i].onclick = function() {
                   // 1. 上的模块选项卡,当前这一个底色会是红色,其余不变(排他思想)
                   // 干掉所有人 其余的li清除 class 这个类
                   for (var i = 0; i < lis.length; i++) {
                       lis[i].className = '';
                  }
                   // 留下我自己
                   this.className = 'current';
                   // 2. 下面的显示内容模块
                   var index = this.getAttribute('index');
                   console.log(index);
                   // 干掉所有人 让其余的item 这些div 隐藏
                   for (var i = 0; i < items.length; i++) {
                       items[i].style.display = 'none';
                  }
                   // 留下我自己 让对应的item 显示出来
                   items[index].style.display = 'block';
              }
          }
       </script>

     

    1.5. H5自定义属性

    自定义属性目的:是为了保存并使用数据。有些数据可以保存到页面中而不用保存到数据库中。

    自定义属性获取是通过getAttribute(‘属性’) 获取。

    但是有些自定义属性很容易引起歧义,不容易判断是元素的内置属性还是自定义属性。

    H5给我们新增了自定义属性:

        <div getTime="20" data-index="2" data-list-name="andy"></div>
       <script>
           var div = document.querySelector('div');
           // console.log(div.getTime);
           console.log(div.getAttribute('getTime'));
           div.setAttribute('data-time', 20);
           console.log(div.getAttribute('data-index'));
           console.log(div.getAttribute('data-list-name'));
           // h5新增的获取自定义属性的方法 它只能获取data-开头的
           // dataset 是一个集合里面存放了所有以data开头的自定义属性
           console.log(div.dataset);
           console.log(div.dataset.index);
           console.log(div.dataset['index']);
           // 如果自定义属性里面有多个-链接的单词,我们获取的时候采取 驼峰命名法
           console.log(div.dataset.listName);
           console.log(div.dataset['listName']);
       </script>

     

    星辰ꦿ.大海
  • 相关阅读:
    Qt之表单布局(QFormLayout)
    Qt之格栅布局(QGridLayout)
    Qt之水平/垂直布局(QBoxLayout、QHBoxLayout、QVBoxLayout)
    Qt之手动布局
    MAC OS下JDK版本切换指南
    Qt之自定义布局管理器(QBorderLayout)
    Qt之自定义布局管理器(QFlowLayout)
    Qt之自定义布局管理器(QCardLayout)
    springMVC获取file,几种转换
    java将白色背景图片转换成无色
  • 原文地址:https://www.cnblogs.com/xc-dh/p/13705666.html
Copyright © 2020-2023  润新知