搜尋
首頁web前端前端問答jquery中data()和attr()的差別是什麼

區別:「$.attr()」每次都從DOM元素中取屬性的值,即和視圖中標籤內的屬性值保持一致;而「$.data()」是從Jquery物件中取值,由於物件屬性值保存在記憶體中,和視圖中的屬性值不一定一致。

jquery中data()和attr()的差別是什麼

本教學操作環境:windows7系統、jquery1.10.2版本、Dell G3電腦。

$.attr()$.data()本質上屬於DOM屬性Jquery物件屬性的區別。

一個簡單的範例

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>Jquery中.attr和.data的区别</title>
    </head>
    <body>
        <p id="app" data-foo="hello"></p>
    </body>
    <script type="text/javascript" src="http://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
    <script type="text/javascript">
        var getAttr1 = $(&#39;#app&#39;).attr(&#39;data-foo&#39;);
        var getData1 = $(&#39;#app&#39;).data(&#39;foo&#39;);
        console.log(&#39;getAttr1: &#39; + getAttr1); //hello
        console.log(&#39;getData1: &#39; + getData1); //hello
 
        $(&#39;#app&#39;).attr(&#39;data-foo&#39;, &#39;world&#39;); //$.attr 设置DOM元素属性值
        var getAttr2 = $(&#39;#app&#39;).attr(&#39;data-foo&#39;);
        var getData2 = $(&#39;#app&#39;).data(&#39;foo&#39;);
        console.log(&#39;getAttr2: &#39; + getAttr2); //world
        console.log(&#39;getData2: &#39; + getData2); //*** hello ***
 
        $(&#39;#app&#39;).data(&#39;foo&#39;, &#39;WORLD&#39;); //$.data 设置DOM node属性值
        var getAttr3 = $(&#39;#app&#39;).attr(&#39;data-foo&#39;);
        var getData3 = $(&#39;#app&#39;).data(&#39;foo&#39;);
        console.log(&#39;getAttr3: &#39; + getAttr3); //world
        console.log(&#39;getData3: &#39; + getData3); //*** WORLD ***
 
    </script>
</html>
  • $.attr()每次都從DOM元素中取屬性的值,也就是和視圖中標籤內的屬性值保持一致。

    • $.attr('data-foo')會從標籤內取得data-foo屬性值;

    • $.attr(' data-foo', 'world')會將字串'world'塞到標籤的'data-foo'屬性;

  • $.data( )是從Jquery物件中取值,由於物件屬性值保存在記憶體中,因此可能和視圖裡的屬性值不一致的情況。

    • $.data('foo')會從Jquery物件內得到foo的屬性值,不是從標籤內取得data-foo屬性值;

    • $.data('foo', 'world')會將字串'world'塞到Jquery物件的'foo'屬性中,而不是塞到視圖標籤的data-foo屬性中。

結合上面程式碼和解釋,大家應該要能理解兩者的差異。

所以$.attr()和$.data()要避免混合用,也就是應該盡量避免以下兩種情況的出現:

  • 透過$. attr()來進行set屬性,然後透過$.data()進行get屬性值;

  • #透過$.data()來進行set屬性,然後透過$.attr()進行get屬性值。

同時從效能的角度來說,建議使用$.data()來進行set和get操作,因為它只是修改的Jquey物件的屬性值,不會引起額外的DOM操作。

相關影片教學推薦:jQuery教學(影片)

以上是jquery中data()和attr()的差別是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
使用HTML5可以播放哪種類型的音頻文件?使用HTML5可以播放哪種類型的音頻文件?Apr 30, 2025 pm 02:59 PM

本文討論了HTML5音頻格式和跨瀏覽器兼容性。它涵蓋MP3,WAV,OGG,AAC和WebM,並建議使用多個來源和後備以實現更廣泛的可訪問性。

SVG和Canvas HTML5元素之間的區別?SVG和Canvas HTML5元素之間的區別?Apr 30, 2025 pm 02:58 PM

SVG和畫布是Web圖形的HTML5元素。基於向量的SVG擅長可擴展性和交互性,而基於像素的畫布則更適合遊戲等性能密集型應用程序。

使用HTML5可能會拖放嗎?使用HTML5可能會拖放嗎?Apr 30, 2025 pm 02:57 PM

HTML5可以通過特定的事件和屬性進行拖放,從而允許自定義,但面臨舊版本和移動設備上的瀏覽器兼容性問題。

&lt; meter&gt之間有什麼區別; tag and&&&&gt;標籤?&lt; meter&gt之間有什麼區別; tag and&&&&gt;標籤?Apr 30, 2025 pm 02:56 PM

本文討論了HTML的&Lt; Meter&Gt; &&&lt;標籤,用於顯示標量值和任務進度。

將以下數據轉換為HTML5中的表格格式?將以下數據轉換為HTML5中的表格格式?Apr 30, 2025 pm 02:54 PM

這是使用HTML5轉換為表格格式的數據,包括響應式設計的示例和策略,造型的最佳實踐以及表格結構中使用的語義HTML5標籤:&lt;! doctype html&gt; &lt; html lang =&

定義圖像圖?定義圖像圖?Apr 30, 2025 pm 02:53 PM

本文討論了網絡設計中的圖像圖,它們的好處,例如增強的導航和參與度以及創建工具。

是Lt; Datalist&gt; tag和&&&&&oflect&gt;標記相同嗎?是Lt; Datalist&gt; tag和&&&&&oflect&gt;標記相同嗎?Apr 30, 2025 pm 02:52 PM

本文討論了&lt; datalist&gt; gt; &&&lt; select&gt;標籤,專注於其功能,用戶互動以及對不同Web開發方案的適用性。

&lt; tig&gt; tag和&&&&img&gt;標籤?&lt; tig&gt; tag和&&&&img&gt;標籤?Apr 30, 2025 pm 02:50 PM

本文討論了HTML的Lt; gt; gt; &&lt; img&gt;標籤,專注於他們的目的,用法和語義優勢。主要論點是&gt; gt;提供更好的結構和訪問

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器