jQuery中DOM操作原則實(shí)例分析
本文實(shí)例講述了jQuery中DOM操作原則。分享給大家供大家參考,具體如下:
一丶Get and Set in One(讀寫一體) 原則
為了更加易于使用,jQuery提供了簡(jiǎn)潔的DOM操作API,其方法往往是讀寫一體的。也就是說,某個(gè)方法既可用于讀取操作,也可用于設(shè)置操作。如果沒有為其傳入表示值的參數(shù),則表示獲取操作,將返回獲取到的數(shù)據(jù);如果為其傳入了表示值的參數(shù),則表示設(shè)置操作,它將設(shè)置DOM元素指定屬性的值。
示例代碼
// 沒有傳入value參數(shù),返回第一個(gè)匹配元素的value元素 var $a = $("a"); //只會(huì)取第一個(gè)匹配的 var $color = a.css("color"); //// 傳入了value參數(shù),設(shè)置所有匹配元素的color樣式為"red" $a.css("color", "red");
二丶Get first Set all(讀取第一個(gè),寫操作所有) 原則
jQuery對(duì)象幾乎所有的DOM操作方法都遵守”Get first Set all”原則。簡(jiǎn)而言之,假設(shè)當(dāng)前jQuery對(duì)象匹配多個(gè)元素,如果使用jQuery對(duì)象的方法來獲取數(shù)據(jù)(“讀”數(shù)據(jù)),則只會(huì)獲取第一個(gè)匹配元素的數(shù)據(jù);如果使用jQuery對(duì)象的方法來設(shè)置元素?cái)?shù)據(jù)(“寫”數(shù)據(jù)),則會(huì)對(duì)所有匹配元素都進(jìn)行設(shè)置操作
示例代碼
var $lis = $("ul li"); // 匹配ul元素的所有后代li元素 var $className = $lis.attr("class"); // 只獲取第一個(gè)匹配的li元素的class屬性 $lis.attr("class", "left"); // 將所有匹配的li元素的class屬性設(shè)為"left"
三丶鏈?zhǔn)骄幊田L(fēng)格
jQuery對(duì)象的所有實(shí)例方法,在沒有特殊的返回需求的情況下,一般都會(huì)返回該jQuery對(duì)象本身(或者其它jQuery對(duì)象),因此我們可以繼續(xù)調(diào)用返回的jQuery對(duì)象上的方法
示例代碼
$("div") // 返回一個(gè)匹配所有div元素的jQuery對(duì)象 .find("ul") // 返回匹配這些div元素中的所有后代ul元素的jQuery對(duì)象 .children() // 返回匹配這些ul元素中的所有子代元素的jQuery對(duì)象 .css("color", "red") // 為這些子代元素設(shè)置css樣式"color: red,并返回當(dāng)前對(duì)象本身 .hide(); // 隱藏這些子代元素,并返回當(dāng)前對(duì)象本身
四丶智能DOM操作,靜默容錯(cuò)
在JS原生DOM操作中,如果通過getElementById()
、getElementsByName()
等方式獲取不到對(duì)應(yīng)的元素,那么將返回null,在null上訪問屬性或方法,將會(huì)拋出異常。
與此不同的是,jQuery在匹配不到對(duì)應(yīng)元素時(shí)將返回一個(gè)空的jQuery對(duì)象,我們?nèi)匀豢梢哉{(diào)用jQuery對(duì)象的方法,而且并不會(huì)報(bào)錯(cuò)。因?yàn)閖Query會(huì)智能地處理這種情況。如果該方法用于獲取數(shù)據(jù),則返回null或undefined;如果該方法用于設(shè)置數(shù)據(jù),則忽略設(shè)置操作,并返回該空對(duì)象本身;如果該方法用于篩選元素,則同樣返回一個(gè)新的jQuery空對(duì)象
更多關(guān)于jQuery相關(guān)內(nèi)容還可查看本站專題:《jQuery操作DOM節(jié)點(diǎn)方法總結(jié)》、《jQuery遍歷算法與技巧總結(jié)》、《jQuery表格(table)操作技巧匯總》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常見經(jīng)典特效匯總》、《jquery選擇器用法總結(jié)》及《jQuery常用插件及用法總結(jié)》
希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。
- jQuery移動(dòng)和復(fù)制dom節(jié)點(diǎn)實(shí)用DOM操作案例
- jQuery學(xué)習(xí)筆記之jQuery的DOM操作
- jQuery 選擇器、DOM操作、事件、動(dòng)畫
- jQuery DOM操作小結(jié)與實(shí)例
- jQuery常見面試題之DOM操作詳析
- 淺談jQuery 選擇器和dom操作
- Jquery基礎(chǔ)教程之DOM操作
- 鋒利的jQuery jQuery中的DOM操作
- jquery中dom操作和事件的實(shí)例學(xué)習(xí) 仿yahoo郵箱登錄框的提示效果
- jquery DOM操作 基于命令改變頁(yè)面
- jQuery DOM操作實(shí)例
相關(guān)文章
ztree實(shí)現(xiàn)左邊動(dòng)態(tài)生成樹右邊為內(nèi)容詳情功能
zTree 是利用 JQuery 的核心代碼,實(shí)現(xiàn)一套能完成大部分常用功能的 Tree 插件。接下來通過本文給大家分享ztree實(shí)現(xiàn)左邊動(dòng)態(tài)生成樹右邊為內(nèi)容詳情功能,需要的朋友參考下吧2017-11-11jQuery實(shí)現(xiàn)對(duì)象轉(zhuǎn)為url參數(shù)的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)對(duì)象轉(zhuǎn)為url參數(shù)的方法,涉及jQuery針對(duì)字符串的遍歷與轉(zhuǎn)換操作相關(guān)技巧,需要的朋友可以參考下2017-01-01jquery實(shí)現(xiàn)動(dòng)態(tài)改變css樣式的方法分析
這篇文章主要介紹了jquery實(shí)現(xiàn)動(dòng)態(tài)改變css樣式的方法,結(jié)合實(shí)例形式分析了jQuery動(dòng)態(tài)操作css樣式的設(shè)置、獲取及應(yīng)用等相關(guān)操作技巧,需要的朋友可以參考下2019-05-05jQuery使用ajax_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了jQuery使用ajax的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07jquery實(shí)現(xiàn)textarea輸入字符控制(仿微博輸入控制字符)
首先獲取輸入框的值然后獲取輸入框的值;如果字?jǐn)?shù)大于500、發(fā)布按鈕禁用否從發(fā)布按鈕啟用,感興趣的朋友可以詳細(xì)了解下哈2013-04-04js和jQuery設(shè)置Opacity半透明 兼容IE6
對(duì)于每一個(gè)網(wǎng)站前端開發(fā)人員,常常都會(huì)遇到設(shè)置div透明度的需求,比如在實(shí)現(xiàn)圖片幻燈片切換效果經(jīng)常就需要使圖片淡入淡出。本文分別對(duì)原生js和jQuery在IE和其它瀏覽器中設(shè)置透明度的方法和相關(guān)注意事項(xiàng)進(jìn)行總結(jié)。2016-05-05Jquery之Ajax運(yùn)用 學(xué)習(xí)運(yùn)用篇
JQuery中Ajax的運(yùn)用相信很多人都已熟悉,本文主要是記錄下個(gè)人實(shí)踐中的應(yīng)用知識(shí),旨在加強(qiáng)記憶。2011-09-09jquery的父、子、兄弟節(jié)點(diǎn)查找,節(jié)點(diǎn)的子節(jié)點(diǎn)循環(huán)方法
下面小編就為大家?guī)硪黄猨query的父、子、兄弟節(jié)點(diǎn)查找,節(jié)點(diǎn)的子節(jié)點(diǎn)循環(huán)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-12-12