zoukankan      html  css  js  c++  java
  • 20151115小问题

    一.关于dataset

    1.html5自定义属性及基础

    html5中我们可以使用data-前缀设置我们需要的自定义属性,来进行一些数据的存放,例如我们要在一个文字按钮上存放相应的id:

    <a href="javascript:;" data-id="2312">测试</a>

    这里的data-前缀就被称为data属性,其可以通过脚本进行定义,也可以应用css属性选择器进行样式设置.数量不受限制,在控制和渲染数据的时候提供了非常强大的控制.

    下面是元素应用data属性的一个例子:

    <div id="day-meal-expense" data-drink="tea" data-food="noodle" data-meal="lunch">$18.3</div>

    要想获取某个属性的值,可以像下面这样使用dataset对象:

        var expenseday=document.getElementById('day-meal-expense');
        var typeOfDrink=expenseday.dataset.drink;
        console.log(typeOfDrink);//tea
        console.log(expenseday.dataset.food);//noodle
        console.log(expenseday.dataset.meal);//lunch

    如果浏览器支持dataset,则会弹出注释内容,如果浏览器不支持dataset则会报错,无法获取属性drink/food/meal的值:对象为null或未定义(如IE9版本).

    data属性基本上所有的浏览器都是支持的,但是dataset对象支持的就比较特殊了,目前仅在Opera 11.1+,Chrome 9+下可以通过javascript,使用dataset访问你自定义的data属性.至于其他浏览器,FireFox 6+(未出)以及Safari 6+(未出)会支持dataset对象,至于IE浏览器,目前看来还是遥遥无期的趋势.

    需要注意的是带边字符连接的名称在使用的时候需要命名驼峰化,即大小写组合书写,这与应用元素的style对象类似,dom.style.borderColor.例如,上面的例子中现有如下data属性,data-meal-time,则我们要获取相应的值可以使用:expenseday.dataset.mealTime

    2.为何要使用dataset

    如果使用传统的方法获取属性值应该会类似下面:

    var typeOfDrink=document.getElementById('day-meal-expense').getAttribute('data-drink');

    现在,如果我们要获得多个自定义的属性值,就要用下面N行代码来实现了:

    var attrs=expenseday.attributes, expense={},i,j;
    for (i=0,j=attrs.length;i<j;i++){
        if(attrs[i].name.substring(0,5)=='data-'){
            expense[attrs[i].name.substring(5)]=attrs[i].value;
        }
    }

    而使用dataset属性,我们根本不需要任何循环去获取你想要的那个值,直接秒杀:

    expense=document.getElementById('day-meal-expense').dataset;

    dataset并不是典型意义上的JavaScript对象,而是个DOMStringMap对象,DOMStringMap是HTML5一种新的含有多个名-值对的交互变量.

    3.dataset的操作

    可以像下面这样操作名-值对:

    charInput=[];
        for(var item in expenseday){
            charInput.push(expenseday[item]);
        }

    上面这几千代码的作用是让所有的自定义属性塞到一个数组中.

    如果你想删除一个data属性,可以这么做:

        delete expenseday.dataset.meal;
        console.log(expenseday.dataset.meal)//undefined

    如果你想给元素添加一个属性,可以这么做:

        expenseday.dataset.dessert='icecream';
        console.log(expenseday.dataset.dessert);//icecream

    4.跟getAttribute相比的速度

    使用dataset操作data要比使用getAttribute稍微慢些.

    但是,如果我们只是处理少量的data数据,这种速度上的差异造成的影响是基本上没有的.反而,我们应该看到,使用dataset操作自适应属性要比其他类似getAttribute的形式要少很多让人头疼的麻烦,并且更具有可读性.因此,权衡来看,操作自定义属性,dataset操作是上选.

    5.什么地方使用dataset

    每次你使用自定义data属性的时候,使用dataset去获取名-值对就是个不错的选择.考虑到现在很多浏览器还是把dataset当作不认识的外星生物看待,所以,在实际使用的时候,有必要进行一下特征检测,看看是否支持dataset,类似下面的使用:

    if(expenseday.dataset){
            expenseday.dataset.dessert='icecream';
        }else{
            expenseday.setAttribute('data-dessert','icecream');
        }

    注意:如果你的应用程序会频繁更新data属性,建议使用JavaScript对象进行数据管理,而不是每次都经由data属性进行更新.

    二.关于字面量赋值,数组赋值

    var a=1,b=2;
    var c=[a,b];
    console.log(c);//[1,2]
    var b=3;
    console.log(c);//[1,2]
    var c=[a,b];
    console.log(c);//[1,3]

    上面赋给a,b的值都是数字,c是由a和b组成的数组,由于a,b的值就是1和2,所以var c=[a,b]就等于var c=[1,2];之后a和b的值再怎么改变变与c=[1,2]无关了.

    引用地址:http://www.zhangxinxu.com/wordpress/2011/06/html5%E8%87%AA%E5%AE%9A%E4%B9%89%E5%B1%9E%E6%80%A7%E5%AF%B9%E8%B1%A1dataset%E7%AE%80%E4%BB%8B/

  • 相关阅读:
    Alpha版本冲刺(一)
    福大软工 · 第七次作业
    福大软工 · 第八次作业(课堂实战)- 项目UML设计(团队)
    福大软工1816 · 第六次作业
    福大软工1816 · 第五次作业
    福大软工1816
    福大软工1816 · 第一次作业
    Python学习
    整理一下软工实践这门课的一些链接
    个人作业——软件工程实践总结作业
  • 原文地址:https://www.cnblogs.com/sunshinegirl-7/p/4967864.html
Copyright © 2011-2022 走看看