HTML5自訂data-* data(obj)屬性和jquery的data()方法的使用_html5教學技巧
data
data屬性
html5
可能大家在使用jquery mobile時,常常會看到data-role、data-theme等的使用,例如:透過以下程式碼即可實現頁眉的效果:
複製程式碼
程式碼如下:我是標題我是標題
透過手機瀏覽,效果如下:
為什麼寫一個data-role="header"就能實現底部為黑色、文字居中顯示的效果呢?
本文提供一個最簡單的實作辦法,讓大家對這些用法有個直覺的了解。
我們寫一個html頁面,自訂一個data-chb="header"的屬性,希望具備這個屬性的div區域背景顏色為黑色,文字為白色,居中顯示;不具備data-chb自訂屬性的div依預設方式顯示,html程式碼如下:
複製程式碼
程式碼如下:程式碼如下:
程式碼如下:
程式碼如下:
我使用了data-chb自訂屬性的div
我沒有使用data-chb自訂屬性,該怎麼展現就怎麼展現;
複製程式碼
複製程式碼
程式碼如下:
然後我們透過以下js方法實現在頁面載入時,動態加入css定義,改變具備data-chb屬性的div的顯示樣式:
複製代碼
代碼如下:
var customAttr = elem.dataset.chb; //也可以透過以下方式取得自訂屬性
//var customAttr = elem.dataset ["chb"];
//如果是我們預先定義好的header值,表示需要處理 if(customAttr=="header"){ //新增樣式
elem.setAttribute ("class","ui_header");
}
}
}
}
最後頁顯示效果如下:
data-myid="3e4ae6c4e">Some awesome data
可是,怎麼來讀取這些資料呢?你當然可以遍歷頁面元素來讀取你想要的屬性,但jquery已經內建了方法來操作這些屬性。使用jQuery的.data()方法來存取這些"data-*" 屬性。其中一個方法就是 .data(obj),這個方法是在 jQuery1.4.3版本後出現的,它能傳回對應的data屬性。
舉個例子,你可以用下面的寫法讀取data-myid屬性值:
複製程式碼
複製程式碼
複製程式碼
程式碼如下:
var myid= jQuery("#awesome").data('myid'); console.log(myid);你還可以在"data-*" 屬性裡使用json語法,例如,如果你寫出下面的html:
複製程式碼
代碼如下:
你可以透過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-*" 資料。
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章
刺客信條陰影:貝殼謎語解決方案
1 個月前
By DDD
Windows 11 KB5054979中的新功能以及如何解決更新問題
3 週前
By DDD
在哪裡可以找到原子中的起重機控制鑰匙卡
1 個月前
By DDD
如何修復KB5055523無法在Windows 11中安裝?
2 週前
By DDD
Inzoi:如何申請學校和大學
3 週前
By DDD

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)