zoukankan      html  css  js  c++  java
  • 自定义属性操作

    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>

     

    星辰ꦿ.大海
  • 相关阅读:
    hdu 6085 bitset优化
    hdu 6070 二分答案+线段树
    hdu 6069 区间筛
    hdu 6058 并查集
    CF 835D D. Palindromic characteristics 字符串hash
    (转)Linux整合apache和tomcat构建Web服务器
    iTunes备份文件路径
    mac下Apache添加限速模块mod_bw
    mac显示隐藏文件夹
    Mac OS X下HomeBrew安装卸载
  • 原文地址:https://www.cnblogs.com/xc-dh/p/13705666.html
Copyright © 2011-2022 走看看