jQuery之超詳盡的DOM操作

超詳盡的DOM操作講解办绝,每一個(gè)函數(shù)都給出了具體實(shí)現(xiàn)冒黑。

1.創(chuàng)建節(jié)點(diǎn)

var $p_node = $("<p></p>")    //創(chuàng)建節(jié)點(diǎn)
var $p_node = $("<p>helloworld</>")  //創(chuàng)建帶有文本的節(jié)點(diǎn)
var $div_node = $("<div id='div1'></div>")    //創(chuàng)建帶有屬性的節(jié)點(diǎn)
$("#p1").append($p_node)    //用append方法添加節(jié)點(diǎn)

2.插入內(nèi)容

2.1內(nèi)部插入

內(nèi)部插入试伙,顧名思義嘁信,就是指向目標(biāo)元素的內(nèi)部插入節(jié)點(diǎn),插入的內(nèi)容在元素內(nèi)部疏叨,類(lèi)似于一種父子關(guān)系潘靖;與之向?qū)?yīng)的是外部插入,外部插入指的是在元素外部插入蚤蔓,插入后的內(nèi)容在元素外部卦溢,更像是一種兄弟關(guān)系。

方法 說(shuō)明
append() 向匹配元素內(nèi)部追加內(nèi)容
appendTo() 顛倒的append用法秀又,將匹配的元素追加到指定元素中
prepend() 向匹配元素內(nèi)部添加前置內(nèi)容
prependTo() 顛倒的prepend用法

append方法和appendTo方法

$("#div1").append($p_node)  //以下結(jié)果是相同的
$($p_node).appendTo("#div1")

prepend和prepend方法

$("#div1").prepend($p_node)  //一線結(jié)果也是一樣的
$($p_node).prependTo("#div1")  //不過(guò)與append不同单寂,元素插入的是,目標(biāo)元素內(nèi)部的前部分

2.2外部插入

方法 說(shuō)明
after() 在匹配的元素之后插入
before() 在匹配的元素之前插入
insertAfter() 將所有匹配的元素插入到另一個(gè)指定的元素集合的后面
insertBefore() 將所有匹配的元素插入到另一個(gè)指定的元素集合的前面

after方法和insertAfter方法

$("#div1").after("<p>helloworld</p>")    //以下效果是一樣的
$("<p>helloworld</p>").insertAfter("#div1")

before()和insertBofore()方法:

$("#div1").before("<p>helloworld</p>")   //以下效果是一樣的
$("<p>helloworld</p>").insertBefore("#div1")

3刪除內(nèi)容

方法 說(shuō)明
remove() 從DOM移除所有匹配的元素
empty() 刪除所有匹配的元素中所有子節(jié)點(diǎn)
detach() 從DOM刪除所有匹配的元素

remove方法:

//remove
$("button").click(function(){  //點(diǎn)擊button移除div2
    $("#div2").remove();
})

empty方法:

//empty
$("button").click(function(){  //清空div2的內(nèi)部包含的內(nèi)容
    $("#div2").empty()
})

? remove和empty的不同:通過(guò)上邊的兩個(gè)例子吐辙,remove移除的是匹配到的元素的所以內(nèi)容(包括該元素自身)宣决,而empty移除的僅是匹配元素的內(nèi)部元素,而它本身被保留了下來(lái)

detach方法:

p.on{     //定義p的一個(gè)狀態(tài)
    background-color: red;     
}
$("p").click(function(){     //對(duì)p綁定一個(gè)事件
    $(this).toggleClass("on")  //切換狀態(tài)
})
var state
$("#detach_button").click(function(){
    if(state){
        state.appendTo("body")   //將state暫存的內(nèi)容添加到body中
        state=null
    }else{
        state=$("p").detach();  //對(duì)p使用detach方法昏苏,返回值暫存state中
    }
})

? 在上面的程序中尊沸,我們對(duì)p標(biāo)簽添加了一個(gè)點(diǎn)擊事件,效果是切換p的背景贤惯,當(dāng)我們對(duì)p使用detach方法時(shí)洼专,將detach分離出的內(nèi)容暫存在state中,當(dāng)再次將state添加到body后孵构,發(fā)現(xiàn)p的click事件仍然存在壶熏,這就是detach與remove的不同之處

4.克隆內(nèi)容

clone([withDataAndEvents],[deepWithDataAndEnents])

參數(shù)說(shuō)明:

  • withDataAndEvents 是否保留事件處理函數(shù)和數(shù)據(jù),默認(rèn)為false
  • deepWithDataAndEvents 是否設(shè)置是否對(duì)子元素也保留處理函數(shù)和數(shù)據(jù)浦译,默認(rèn)值與第一個(gè)參數(shù)匹配
$("#para1").click(function(){
    $(this).toggleClass("on")
})
$("#clone").click(function(){
    $("#para1").clone(false).insertAfter("#clone")
})

當(dāng)withDataAndEvents值為false時(shí)棒假,點(diǎn)擊button會(huì)添加一個(gè)p標(biāo)簽溯职,但是點(diǎn)擊p并沒(méi)有反映,而當(dāng)值為true時(shí)帽哑,clone方法會(huì)復(fù)制處理函數(shù)谜酒,所以此時(shí)點(diǎn)擊p標(biāo)簽時(shí)就會(huì)出現(xiàn)樣式的變換

5.替換內(nèi)容

replaceWith方法:

$("#replace").click(function(){
    $(this).replaceWith("<div>"+$(this).text()+"</div>")
})

? replaceWIth方法是將選中的元素替換為目標(biāo)元素,此操作是移動(dòng)妻枕,不是復(fù)制僻族。

replaceAll方法:

$("#replaceAll").click(function(){
    $("<div>"+$(this).text()+"</div>").replaceAll(this)
})

? 兩個(gè)方法實(shí)際上是一對(duì)相反的操作,上面兩個(gè)程序結(jié)果相同

6.包裹內(nèi)容

6.1外包

wrap方法:

$("p").wrap("<li></li>")為p標(biāo)簽外包裹li標(biāo)簽

6.2內(nèi)包

wrapInner方法:

$("div").wrapInner("<li></li>")為div內(nèi)包裹一個(gè)li標(biāo)簽

6.3總包

wrapAll

其效果在所有元素外包一層結(jié)構(gòu)屡谐。

$("div").wrapAll("<li></li>")

6.4卸包

$("div").unwrap();

刪除父級(jí)元素

7.屬性操作

使用prop方法來(lái)設(shè)置屬性:

$("input[checked='checked']").prop({
    disabled:true
})               //設(shè)置被選中的checkbox為不可用狀態(tài)

當(dāng)prop只有一個(gè)參數(shù)時(shí)述么,此時(shí)表示讀取元素的屬性,該方法返回的是元素的屬性:

console.log($("input[checked='checked']").prop("disabled"))
//result : true

使用attr方法來(lái)設(shè)置屬性:

$("#link").attr("href","https://www.baidu.com")
//使用attr方法改變a標(biāo)簽的href

同理愕掏,當(dāng)函數(shù)參數(shù)只有一個(gè)時(shí)度秘,返回的同樣是元素的屬性

console.log($("#link").attr("href"))
//result : https://www.baidu.com

? attr方法和prop方法的不同:使用prop的原則,1.只添加屬性名饵撑,而不添加屬性值就會(huì)生效剑梳。2.只要屬性為true/false

removeProp方法:

$("a").prop("size","10");  //給a設(shè)置一個(gè)自定義屬性size
console.log($("a").prop("size"))  //10
$("a").removeProp("size")   //使用removeProp方法刪除屬性
console.log($("a").prop("size"))  //undefined

removeAttr方法:

$("input").removeAttr("disabled")  

8.類(lèi)操作

addClass: 添加類(lèi)

$("p").addClass("blue size")   //為p標(biāo)簽添加兩個(gè)類(lèi)
p.blue{
    background-color: blue;
}
p.size{
    font-size: 30px;
}

removeClass: 移除類(lèi)

//removeClass
$("#removeClass").click(function(){   //點(diǎn)擊removeClass按鈕刪除p標(biāo)簽的兩個(gè)類(lèi)
    $("p").removeClass("blue size")
})

toggleClass: 切換類(lèi)

//toggleClass
$("#toggleClass").click(function(){    //點(diǎn)擊toggleClass按鈕 
    $("p").toggleClass("red smallSize",true)  //第二個(gè)參數(shù)為true,原先的類(lèi)被移除
    $("p").toggleClass("blue size",false)  //第二個(gè)參數(shù)為false,添加新類(lèi)
})

hasClass:判斷是否存在該類(lèi)

//hasClass
console.log($("p").hasClass("blue"))
//result: true

9.讀寫(xiě)文本和值

1.使用html方法讀寫(xiě)HTML

//html
var d=$("#div1").html()
$("#div2").html(d)

2.用text方法讀寫(xiě)文本

//text
console.log($("p").text());  //讀取p標(biāo)簽的文本

3.用val方法讀寫(xiě)值

$("#getVal").click(function(){  //點(diǎn)擊getVal按鈕使用val方法獲取文本框的值
    console.log($("input[type='text']").val())
})

10樣式表操作

css方法操作樣式表

$("p").css({   //為p標(biāo)簽設(shè)置CSS屬性
    "font-size":"20px",
    "background-color":"gray"
})

使用height和width方法設(shè)置元素大小

$("#div1").height(100)
$("#div1").width("80%")

11.訪問(wèn)文檔樹(shù)

jQuery定義了children(),next(),prev(),parent()四種基本方法來(lái)遍歷元素

方法 說(shuō)明
children() 獲取當(dāng)前元素子元素
next() 獲取當(dāng)前元素下一個(gè)同級(jí)元素
prev() 獲取當(dāng)前元素上一個(gè)同級(jí)元素
parent() 獲取當(dāng)前元素的父元素
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末滑潘,一起剝皮案震驚了整個(gè)濱河市垢乙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌语卤,老刑警劉巖追逮,帶你破解...
    沈念sama閱讀 217,277評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異粹舵,居然都是意外死亡羊壹,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門(mén)齐婴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)油猫,“玉大人,你說(shuō)我怎么就攤上這事柠偶∏檠” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,624評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵诱担,是天一觀的道長(zhǎng)毡证。 經(jīng)常有香客問(wèn)我,道長(zhǎng)蔫仙,這世上最難降的妖魔是什么料睛? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,356評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上恤煞,老公的妹妹穿的比我還像新娘屎勘。我一直安慰自己,他們只是感情好居扒,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布概漱。 她就那樣靜靜地躺著,像睡著了一般喜喂。 火紅的嫁衣襯著肌膚如雪瓤摧。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,292評(píng)論 1 301
  • 那天玉吁,我揣著相機(jī)與錄音照弥,去河邊找鬼。 笑死进副,一個(gè)胖子當(dāng)著我的面吹牛这揣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播敢会,決...
    沈念sama閱讀 40,135評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼曾沈,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼这嚣!你這毒婦竟也來(lái)了鸥昏?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 38,992評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤姐帚,失蹤者是張志新(化名)和其女友劉穎吏垮,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體罐旗,經(jīng)...
    沈念sama閱讀 45,429評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡膳汪,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了九秀。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片遗嗽。...
    茶點(diǎn)故事閱讀 39,785評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖鼓蜒,靈堂內(nèi)的尸體忽然破棺而出痹换,到底是詐尸還是另有隱情,我是刑警寧澤都弹,帶...
    沈念sama閱讀 35,492評(píng)論 5 345
  • 正文 年R本政府宣布娇豫,位于F島的核電站,受9級(jí)特大地震影響畅厢,放射性物質(zhì)發(fā)生泄漏冯痢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望浦楣。 院中可真熱鬧袖肥,春花似錦、人聲如沸椒振。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,723評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)澎迎。三九已至庐杨,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間夹供,已是汗流浹背灵份。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,858評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留哮洽,地道東北人填渠。 一個(gè)月前我還...
    沈念sama閱讀 47,891評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像鸟辅,于是被迫代替她去往敵國(guó)和親氛什。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 一匪凉、樣式篇 第1章 初識(shí)jQuery (1)環(huán)境搭建 進(jìn)入官方網(wǎng)站獲取最新的版本 http://jquery.co...
    凜0_0閱讀 3,380評(píng)論 0 44
  • 第1章 簡(jiǎn)介 第2章 DOM節(jié)點(diǎn)的創(chuàng)建 2-1 DOM創(chuàng)建節(jié)點(diǎn)及節(jié)點(diǎn)屬性 通過(guò)JavaScript可以很方便的獲...
    mo默22閱讀 812評(píng)論 0 8
  • title: 《鋒利的jQuery》三再层、jQuery的DOM操作date: 2017-07-03 09:23:54...
    Gary23閱讀 380評(píng)論 0 1
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)聂受,斷路器蒿秦,智...
    卡卡羅2017閱讀 134,654評(píng)論 18 139
  • 大道至簡(jiǎn)碗旅。 真正的道理都是能簡(jiǎn)單描述的。但能不能理解扛芽,理解到什么程度骂蓖,是和閱歷和個(gè)人的悟性相關(guān)的。 好多好多年川尖,感...
    花開(kāi)兮緩歸閱讀 1,110評(píng)論 0 1