4月12日學習筆記——jQuery操作屬性和樣式

来源:http://www.cnblogs.com/little-jelly/archive/2016/04/12/5383001.html
-Advertisement-
Play Games

區分 DOM 屬性和元素屬性 區分 DOM 屬性和元素屬性 通常開發人員習慣將id,src,alt等叫做這個元素的"屬性"。我們將其稱為"元素屬性"。但是在解析成 DOM 對象時,實際瀏覽器最後會將標簽元素解析成"DOM 對象", 並且將元素的"元素屬性"存儲為"DOM 屬性",兩者是有區別的。 甚 ...


  • 區分 DOM 屬性和元素屬性

1 <img src="images/image.1.jpg" id="hibiscus" alt="Hibiscus" class="classA" />

通常開發人員習慣將id,src,alt等叫做這個元素的"屬性"。我們將其稱為"元素屬性"。但是在解析成 DOM 對象時,實際瀏覽器最後會將標簽元素解析成"DOM 對象", 並且將元素的"元素屬性"存儲為"DOM 屬性",兩者是有區別的。

甚至有些"元素屬性"和"DOM 屬性"的名稱都不一樣,比如上面的元素屬性 class, 轉換為 DOM 屬性後對應 className。

牢記, 在 javascript 中我們可以直接獲取或設置"DOM 屬性":

1 <script type="text/javascript">
2     $(function() {
3         var img1 = document.getElementById("hibiscus");
4         alert(img1.alt);
5         img1.alt = "Change the alt element attribute";
6         alert(img1.alt);
7         img1.className = "classB";
8     })
9 </script>

所以如果要設置元素的 CSS 樣式類, 要使用的是 DOM 屬性"className"而不是元素屬性"class"。


 

  • 操作"Dom 屬性"

在 jQuery 提供了each()函數用於遍歷 jQuery 包裝集,其中的this指針是一個 DOM 對象,所以我們可以應用這一點配合原生 javascript 來操作元素的 DOM 屬性:

1 $("img").each(function(index) {
2     alert("index:" + index + ", id:" + this.id + ", alt:" + this.alt);
3     this.alt = "changed";
4     alert("index:" + index + ", id:" + this.id + ", alt:" + this.alt);
5 });

  • 操作"元素屬性"

我們可以使用 javascript 中的getAttributesetAttribute來操作元素的"元素屬性"。在 jQuery 中給你提供了attr()包裝集函數, 能夠同時操作包裝集中所有元素的屬性:

雖然我們可以使用removeAttr(name)刪除元素屬性,但是對應的 DOM 屬性是不會被刪除的, 只會影響 DOM 屬性的值.比如將一個input元素的readonly元素屬性去掉,會導致對應的 DOM 屬性變成false(即input變成可編輯狀態).


  • 修改 CSS 類和樣式

下表是修改 CSS 類相關的 jQuery 方法:

註意addClass(class)removeClass(classes)的參數可以一次傳入多個 css 類, 用空格分割。removeClass 方法的參數可選, 如果不傳入參數則移除全部 CSS 類。

同樣當我們想要修改元素的具體某一個 CSS 樣式,即修改元素屬性"style"時, jQuery 也提供了相應的方法:


  • 獲取常用屬性

<!doctype html>
<html lang="zh">
<head>
  <meata charset="utf-8"/>
  <title>get object width</title>
  <script src="jquery-1.11.2.min.js"></script>
  <script>
    $(function() {
      alert("attr(\"width\"):" + $("#testDiv").attr("width")); //undifined
      alert("css(\"width\"):" + $("#testDiv").css("width")); //auto(ie6) 或 1264px(ff)
      alert("width():" + $("#testDiv").width()); //正確的數值 1264
      alert("style.width:" +  $("#testDiv")[0].style.width); //空值
    })
  </script>
</head>
<body>
  <div id="testDiv">test text</div>
</body>
</html>

我們希望獲取測試圖層的寬度,使用 attr 方法獲取"元素特性"為 undefined, 因為並沒有為 div 添加 width。而使用 css()方法雖然可以獲取到 style 屬性的值, 但是在不同瀏覽器里返回的結果不同,IE6 下返回 auto,而 FF 下雖然返回了正確的數值但是後面帶有"px"。所以 jQuery 提供了 width()方法,此方法返回的是正確的不帶 px 的數值。

針對上面的問題,jQuery 為常用的屬性提供了獲取和設置的方法,比如 width()用戶獲取元素的寬度,而 width(val)用來設置元素寬度。

下麵這些方法可以用來獲取元素的常用屬性值:

1. 寬和高相關 Height and Width

     

outerWidth 可以接受一個 bool 值參數表示是否計算 margin 值。

2. 位置相關 Positioning

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本篇主要介紹HTML5增加的語義元素中關於頁面結構方面的,包含: <article>、<aside>、<figure>、<figcaption>、<footer>、<header>、<main>、<nav>、<section>等元素。 目錄 1. 語義元素介紹 1.1 何為語義元素 1.2 特點 2 ...
  • 什麼是web app? WebApp是指基於Web的系統和應用,其作用是向廣大的最終用戶發佈一組複雜的內容和功能。 說的淺顯易懂點兒就是因為移動互聯網特別火爆,很多企業公司也都想擁有一個屬於自己的app,但是因為原生app開發的成本比較高,而且後期維護比較困難,這些開發成本和後期維護成本對於個人創業 ...
  • function db_connect()//連接資料庫 { @$db =mysql_connect('localhost','root','test'); if(!$db) throw new Exception('連接資料庫失敗!請重試!'); mysql_select_db('book'); ...
  • 上一篇文章介紹瞭如何利用CSS選擇器為元素應用各種豐富的樣式,每個合法的文檔都會生成一個結構樹,瞭解這一點,就能根據元素的祖先、屬性、兄弟等元素穿件選擇器選擇元素。 本篇文章將討論3中機制之間的關係:特殊性、繼承和層疊 特殊性 有的時候我們為同一個元素設置了不同的CSS樣式代碼,那麼元素會啟用哪一個 ...
  • 打包的目的和意義就不用敘述了直接上乾貨 http://www.gruntjs.net/getting-started裡面的教程也太簡單了,需要下一番功夫去研究才行。本文將grunt打包的常用方法都用實例描述,更加清晰易懂。 1. 第一個簡單的grunt打包 1)需要安裝nodejs:http://w ...
  • 所謂的瀏覽器相容性問題,是指因為不同的瀏覽器對同一段代碼有不同的解析,造成頁面顯示效果不統一的情況。在大多數情況下,我們的需求是,無論用戶用什麼瀏覽器來查看我們的網站或者登陸我們的系統,都應該是統一的顯示效果。所以瀏覽器的相容性問題是前端開發人員經常會碰到和必須要解決的問題。 在學習瀏覽器相容性之前 ...
  • sublime text3 是個很好的編輯工具,前端程式員覺得她很好,我是在一次視頻中看到她能幫助自動完成很多快捷的操作。 為什麼安裝? 如果想要給sublime text 中安裝別的插件(這裡稱呼為 包),那麼首先得先給她安裝個插件管理器,也就是包管理器 package control 怎麼安裝她... ...
  • 值得打一個helloworld好好紀念一下! <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Document</title></head><body> <strong>HELLO WORLD</strong>< ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...