jquery 如何動態添加、刪除class樣式方法介紹

取與設置樣式 獲取class和設置class都可以使用attr()方法來完成。例如使用attr()方法來獲取p元素的class,jquery代碼如下: 

複製代碼 代碼如下:


var p_class = $("p").attr("class"); //獲取p元素的class 
[html] 
使用attr()方法來設置p元素的class,JQuery代碼如下: 
[code] 
1 $("p").attr("'class", "high"); //設置p元素的class爲 "high" 


大多數情況下,它是將原來的class替換爲新的class,而不是在原來的基礎上追加新的class。 
追加樣式 什麼是追加class呢?假如p元素原本的class爲myClass,那麼追加一個名叫high的class後,class屬性變爲 “myClass high”,即myClass和high兩種樣式的疊加。JQuery提供了專門的addClass()方法來追加樣式。爲了使例子更容易理解,首先在 style標籤裏添加另一組樣式: 

複製代碼 代碼如下:


1 .high{ color:red; } 
2 .another{ font-style:italic; color:blue; } 
後在網頁中添加一個“追加class類”的按鈕,按鈕的事件代碼如下: 
1 $("#btn_3").click(function(){ 
2 $("#nm_p").addClass("another"); // 追加樣式 
3 }); 


後當單擊“追加class類”按鈕時,p元素樣式就會變爲斜體,而先前的紅色字體也會變爲藍色。此時p元素同時擁有兩個class值,即"high"和"another"。在CSS中有以下兩條規定。 
1.如果給一個元素添加了多個class值,那麼就相當於合併了它們的樣式。 2.如果有不同的class設定了同一樣式屬性,則後者覆蓋前者。 在上例中,相當於給p元素添加了如下樣式: 

複製代碼 代碼如下:


1 color : red; /* 字體顏色設置紅色*/ 
2 font-style:italic; 
3 color:blue; 


以上的樣式中,存在兩個“color”屬性,而後面的“color”屬性會覆蓋前面的“color”屬性,因此最終的“color”屬性的值爲“blue”,而不是“red”。 
移除樣式 如果用戶單擊某個按鈕時,要刪除class的某個值,那麼可以使用與addClass()方法相反的removeClass()方法來完成,它的 作用是從匹配的元素中刪除全部或者指定的class。例如可以使用如下的JQuery代碼來刪除p元素中值爲“high”的class: 

複製代碼 代碼如下:


1 $("p").removeClass("high"); //移除p元素中值爲"high"的class 
果要把p元素的兩個class都刪除,就要使用兩次removeClass()方法,代碼如下: 
1 $("p").removeClass("high").removeClass("another"); 
Query提供了更簡單的方法。可以以空格的方式刪除多個class名,代碼如下: 
1 $("p").removeClass("high another"); 
外,還可以利用removeClass()方法的一個特性來完成同樣的效果。當它不帶參數時,就會將class的值全部刪除,JQuery代碼如下: 
1 $("p").removeClass(); //移除p元素的所有class 
換樣式 JQuery中有一個方法toggle(),JQuery代碼如下: 
1 toggleBtn.toggle(function(){ 
2 //元素顯示 代碼③ 
3 }, function(){ 
4 //元素隱藏 代碼④ 
5 }) 


oggle()方法此處的作用是交替執行代碼③和代碼④兩個函數,如果元素原來是顯示的,則隱藏它:如果元素原來是隱藏的,則顯示它。此時,toggle()方法主要是控制行爲上的重複切換。 
另外JQuery還提供了一個toggleClass()方法控制樣式上的重複切換。如果類名存在則刪除它,如果類名不存在則添加它。例如對p元素進行toggleClass()方法操作。 

複製代碼 代碼如下:


1 $("p").toggleClass("another"); //重複切換類名“another” 


不斷單擊“切換樣式”按鈕時,p元素的class的值就會在“myClass”和“myClass another”之間重複切換。 
判斷是否含有某個樣式 hasClass()可以用來判斷元素中是甭含有某個class,如果有,則返回true,否則返回false。例如可以使用下面的代碼來判斷p元素中是否含有“another”的class: 

複製代碼 代碼如下:


1 $("p").hasClass("another"); 


個方法是爲了增強代碼可讀性面產生的。在JQuery內部實際上是調用了is()方法來完成這個功能的.該方法等價於如下代碼: 

複製代碼 代碼如下:


view sourceprint? 1 $("p").is(".another"); //is("."+class); 


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章