jQuery中DOM操作原則實例分析
本文實例講述了jQuery中DOM操作原則。分享給大家供大家參考,具體如下:
一丶Get and Set in One(讀寫一體) 原則
為了更加易于使用,jQuery提供了簡潔的DOM操作API,其方法往往是讀寫一體的。也就是說,某個方法既可用于讀取操作,也可用于設(shè)置操作。如果沒有為其傳入表示值的參數(shù),則表示獲取操作,將返回獲取到的數(shù)據(jù);如果為其傳入了表示值的參數(shù),則表示設(shè)置操作,它將設(shè)置DOM元素指定屬性的值。
示例代碼
// 沒有傳入value參數(shù),返回第一個匹配元素的value元素
var $a = $("a");
//只會取第一個匹配的
var $color = a.css("color");
//// 傳入了value參數(shù),設(shè)置所有匹配元素的color樣式為"red"
$a.css("color", "red");
二丶Get first Set all(讀取第一個,寫操作所有) 原則
jQuery對象幾乎所有的DOM操作方法都遵守”Get first Set all”原則。簡而言之,假設(shè)當(dāng)前jQuery對象匹配多個元素,如果使用jQuery對象的方法來獲取數(shù)據(jù)(“讀”數(shù)據(jù)),則只會獲取第一個匹配元素的數(shù)據(jù);如果使用jQuery對象的方法來設(shè)置元素數(shù)據(jù)(“寫”數(shù)據(jù)),則會對所有匹配元素都進(jìn)行設(shè)置操作
示例代碼
var $lis = $("ul li"); // 匹配ul元素的所有后代li元素
var $className = $lis.attr("class"); // 只獲取第一個匹配的li元素的class屬性
$lis.attr("class", "left"); // 將所有匹配的li元素的class屬性設(shè)為"left"
三丶鏈?zhǔn)骄幊田L(fēng)格
jQuery對象的所有實例方法,在沒有特殊的返回需求的情況下,一般都會返回該jQuery對象本身(或者其它jQuery對象),因此我們可以繼續(xù)調(diào)用返回的jQuery對象上的方法
示例代碼
$("div") // 返回一個匹配所有div元素的jQuery對象
.find("ul") // 返回匹配這些div元素中的所有后代ul元素的jQuery對象
.children() // 返回匹配這些ul元素中的所有子代元素的jQuery對象
.css("color", "red") // 為這些子代元素設(shè)置css樣式"color: red,并返回當(dāng)前對象本身
.hide(); // 隱藏這些子代元素,并返回當(dāng)前對象本身
四丶智能DOM操作,靜默容錯
在JS原生DOM操作中,如果通過getElementById()、getElementsByName()等方式獲取不到對應(yīng)的元素,那么將返回null,在null上訪問屬性或方法,將會拋出異常。
與此不同的是,jQuery在匹配不到對應(yīng)元素時將返回一個空的jQuery對象,我們?nèi)匀豢梢哉{(diào)用jQuery對象的方法,而且并不會報錯。因為jQuery會智能地處理這種情況。如果該方法用于獲取數(shù)據(jù),則返回null或undefined;如果該方法用于設(shè)置數(shù)據(jù),則忽略設(shè)置操作,并返回該空對象本身;如果該方法用于篩選元素,則同樣返回一個新的jQuery空對象
更多關(guān)于jQuery相關(guān)內(nèi)容還可查看本站專題:《jQuery操作DOM節(jié)點方法總結(jié)》、《jQuery遍歷算法與技巧總結(jié)》、《jQuery表格(table)操作技巧匯總》、《jQuery擴展技巧總結(jié)》、《jQuery常見經(jīng)典特效匯總》、《jquery選擇器用法總結(jié)》及《jQuery常用插件及用法總結(jié)》
希望本文所述對大家jQuery程序設(shè)計有所幫助。
相關(guān)文章
jquery鼠標(biāo)懸停導(dǎo)航下劃線滑出效果
這篇文章主要為大家詳細(xì)介紹了jquery鼠標(biāo)懸停導(dǎo)航下劃線滑出效果,菜單鼠標(biāo)懸停出現(xiàn)下劃線,向兩邊擴展的效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-09-09
jQuery事件綁定方法學(xué)習(xí)總結(jié)(推薦)
下面小編就為大家?guī)硪黄猨Query事件綁定方法學(xué)習(xí)總結(jié)(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11
jQuery中與toggleClass等價的程序段 以及未來學(xué)習(xí)的方向
昨天開始學(xué)jQuery,js是我前端設(shè)計技術(shù)的一塊心病,一直沒有找到很好的學(xué)習(xí)辦法。最近突然開悟,可以學(xué)jQuery呀,這個東西比較好學(xué)。2010-03-03
jQuery插件FusionCharts繪制的3D餅狀圖效果實例【附demo源碼下載】
這篇文章主要介紹了jQuery插件FusionCharts繪制的3D餅狀圖效果,結(jié)合完整實例形式分析了基于FusionCharts圖形插件繪制餅狀圖的操作技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
最佳6款用于移動網(wǎng)站開發(fā)的jQuery 圖片滑塊插件小結(jié)
隨著智能手機的普及,越來越多的用戶喜歡通過手機中瀏覽網(wǎng)頁。今天這篇文章為大家推薦最佳6款用于移動應(yīng)用的 jQuery 圖片滑塊插件,這些插件很好的處理了觸屏事件,效果平滑,幫助你構(gòu)建用戶體驗良好的移動網(wǎng)站2012-07-07

