中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

HTML5怎么自定義data-* data(obj)屬性和jquery的data()方法

發布時間:2021-07-22 10:43:37 來源:億速云 閱讀:168 作者:chen 欄目:web開發

本篇內容介紹了“HTML5怎么自定義data-* data(obj)屬性和jquery的data()方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

可能大家在使用jquery mobile時,經常會看到data-role、data-theme等的使用,比如:通過如下代碼即可實現頁眉的效果:

代碼如下:


<div data-role="header">
   <h2>我是標題</h2>
</div>


通過手機瀏覽,效果如下:

HTML5怎么自定義data-* data(obj)屬性和jquery的data()方法HTML5怎么自定義data-* data(obj)屬性和jquery的data()方法

為什么寫一個data-role="header"就能實現底部為黑色、文字居中顯示的效果呢?

本文提供一種最簡單的實現辦法,讓大家對這些用法有個直觀的了解。

我們寫一個html頁面,自定義一個data-chb="header"的屬性,希望具備這個屬性的div區域背景顏色為黑色,文字為白色,居中顯示;不具備data-chb自定義屬性的div按照默認方式顯示,html代碼如下:

代碼如下:


<body>
 <div data-chb="header">
   <h2>我是使用了data-chb自定義屬性的div</h2>
 </div>
 <br/>
 <div>
   我沒有使用data-chb自定義屬性,該怎么展現就怎么展現;
 </div>
</body>


要想實現"背景顏色為黑色,文字為白色,居中顯示"的顯示效果,我們定義如下的css:

代碼如下:


<style>
.ui_header {
 background-color: black;
 text-align: center;
 color:white;
 border:1px solid #000;
}
</style>


然后我們通過如下js方法實現在頁面加載時,動態添加css定義,改變具備data-chb屬性的div的顯示樣式:

代碼如下:


     <script type="text/javascript">
     window.onload=function(){
       var elems = document.getElementsByTagName("div");
       if(elems!=null&&elems.length>0){
         var length = elems.length;
         //遍歷所有DIV控件
         for(var i=0;i<length;i++){
           var elem = elems[i];
           //獲取該控件的自定義屬性
           var customAttr = elem.dataset.chb;
           //也可以通過如下方式獲得自定義屬性
           //var customAttr = elem.dataset["chb"];
           //如果是我們預先定義好的header值,表示需要處理
           if(customAttr=="header"){
             //添加樣式
             elem.setAttribute("class","ui_header");
           }
         }
       }
     }
   </script>


最后頁面顯示效果如下:

HTML5怎么自定義data-* data(obj)屬性和jquery的data()方法

人們總喜歡往HTML標簽上添加自定義屬性來存儲和操作數據。但這樣做的問題是,你不知道將來會不會有其它腳本把你的自定義屬性給重置掉,此外,你這樣做也會導致html語法上不符合Html規范,以及一些其它副作用。這就是為什么在HTML5規范里增加了一個自定義data屬性,你可以拿它做很多有用的事情。

你可以去讀一下HTML5的詳細規范,但這個自定義data屬性的用法非常的簡單,就是你可以往HTML標簽上添加任意以 "data-"開頭的屬性,這些屬性頁面上是不顯示的,它不會影響到你的頁面布局和風格,但它卻是可讀可寫的。
下面的一個代碼片段是一個有效的HTML5標記

代碼如下:


<div id="awesome"
data-myid="3e4ae6c4e">Some awesome data</div>


可是,怎么來讀取這些數據呢?你當然可以遍歷頁面元素來讀取你想要的屬性,但jquery已經內置了方法來操作這些屬性。使用jQuery的.data()方法來訪問這些"data-*" 屬性。其中一個方法就是 .data(obj),這個方法是在 jQuery1.4.3版本后出現的,它能返回相應的data屬性。
舉個例子,你可以用下面的寫法讀取 data-myid屬性值:

代碼如下:


var myid= jQuery("#awesome").data('myid');


console.log(myid);你還可以在"data-*" 屬性里使用json語法,例如,如果你寫出下面的html:

代碼如下:


<div id="awesome-json" data-awesome='{"game":"on"}'></div>


你可以通過js直接訪問這個數據,通過json的key值,你能得到相應的value:

代碼如下:


var gameStatus= jQuery("#awesome-json").data('awesome').game;


console.log(gameStatus);你也可以通過.data(key,value)方法直接給"data-*" 屬性賦值。一個重要的你要注意的事情是,這些"data-*" 屬性應該和它所在的元素有一定的關聯,不要把它當成存放任意東西的存儲工具。
譯者補充:盡管"data-*" 是HTML5才出現的屬性,但jquery是通用的,所以,在非HTML5的頁面或瀏覽器里,你仍然可以使用.data(obj)方法來操作"data-*" 數據。

“HTML5怎么自定義data-* data(obj)屬性和jquery的data()方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新乡市| 民勤县| 环江| 安平县| 商丘市| 泗水县| 枝江市| 鲁山县| 昔阳县| 洛隆县| 肥城市| 金昌市| 南江县| 明水县| 安塞县| 苍南县| 岐山县| 克什克腾旗| 雷山县| 固安县| 乐平市| 揭西县| 琼海市| 德钦县| 呈贡县| 平凉市| 丽江市| 措美县| 蓝山县| 信丰县| 金山区| 维西| 井研县| 潜江市| 松阳县| 兴安盟| 乐都县| 中山市| 塔河县| 甘德县| 茌平县|