zoukankan      html  css  js  c++  java
  • html5 data-*自定义属性取值

    demo:

    <!DOCTYPE HTML>
    <html>
    <head>
    <title></title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta http-equiv="pragma" content="no-cache" />
    <meta http-equiv="cache-control" content="no-cache" />
    <meta http-equiv="expires" content="0" />
    <script src="<%=path%>/js/jquery/jquery-1.8.3.min.js"> </script>
     
    </head>
    <body>
        <div id="divDom" data-name="userName" data-age="26" data-address="北京市">data-test</div>
    </body>
    <script type="text/javascript">
        $(function(){//$(element).data(keyName),jquery也提供了兼容方法。
            var divDom = document.getElementById('divDom'),dataSet = get_dataset(divDom);
            console.info("name:"+dataSet.name);
            console.info("age:"+dataSet["age"]);
        });
        //带兼容的函数  
        function get_dataset(ele){  
            if(ele.dataset)  
                return ele.dataset;  
            else{  
            //以下是兼容代码  
                var dataset = {};  
                var ele_split = ele.outerHTML.split(" ");  
                for(var i = 0,element; i < ele_split.length; i++)      
                {  
                    element = ele_split[i];  
                    if (element.substring(0,4) == "data") {   
                        if (element.indexOf(">") !=  -1) {   
                            element = element.split(">")[0];  
                        };  
                        ele_key=element.split("=")[0].slice(5);  
                        ele_value=element.split("=")[1].slice(1,-1);  
                        if(ele_key.indexOf("-") ==  -1){  
                            dataset[ele_key] = ele_value;  
                        }else{  
                            ele_keys=ele_key.split("-");  
                            ele_key=ele_keys[0];  
                            for(i=1;i<ele_keys.length;i++){  
                                ele_key+=replaceReg(ele_keys[i]);  
                            }                 
                        }  
                    };  
                }  
                return dataset;  
            }  
          
        }  
        //正则表达式变换首字母大写  
        function replaceReg(str){   
            var reg = /(w)|s(w)/g;   
            str = str.toLowerCase();   
            return str.replace(reg,function(m){return m.toUpperCase()})   
       } 
    </script>
    </html>
  • 相关阅读:
    [BZOJ4876][ZJOI2017]线段树
    [FJOI2016]建筑师(斯特林数)
    WC2018伪题解
    [BZOJ3514]CodeChef MARCH14 GERALD07加强版(LCT+主席树)
    [BZOJ2594][WC2006]水管局长加强版(LCT+Kruskal)
    [洛谷3796]【模板】AC自动机(加强版)
    [洛谷3808]【模板】AC自动机(简单版)
    [BZOJ3261]最大异或和
    [BZOJ3439]Kpm的MC密码
    [POI2006]Periods of Words
  • 原文地址:https://www.cnblogs.com/xtreme/p/6672300.html
Copyright © 2011-2022 走看看