首頁 web前端 js教程 JQuery中parent(),parents(),parentsUntil()區別聯繫以及使用方法教程

JQuery中parent(),parents(),parentsUntil()區別聯繫以及使用方法教程

Jun 24, 2017 am 09:28 AM
jquery parent 差別

parent()其實很簡單, 就是指定選擇器中每個元素的外邊的一層。例如$("p"),那麼就是結果就是包裹著

的資料 如:

。如果有多個

則結果集為物件集。可以用eq(i),first(),last()定位。若資料為

  • 怎麼使用$("p").parent("li")查詢的結果為空,因為

    的外層為< ;p>。

    JQuery手冊中

    <p><p>Hello</p></p><p class="selected"><p>Hello Again</p></p>
    登入後複製
    <pre class="brush:php;toolbar:false">$("p").parent(".selected");
    登入後複製
    //结果:
    登入後複製
    [ <p class="selected"><p>Hello Again</p></p> ]
    登入後複製

    可以理解為

    $("p").parent().find(".selected");
    登入後複製

    找直接父親中類為selected的那一個或幾個。

    所以parent()的實用性不強。

    parents()就是選擇器中每個元素的所有的父親,如果選擇器有多個父親則回傳的是個結果集。結果集的結果是由內層向外層排列的。最外層就是整個html元素了,第一個就是緊貼選擇器中每個元素的元素。結果集中並沒有重複的元素。

    同理當帶參數時,也是在結果集中find製定的元素

    $("p").parents(".selected");
    登入後複製
    $("p").parents().find(".selected");
    登入後複製

    因此我們想找到選擇器的某個父親,就要先找到他的所有父親,然後在find這個父親。

    當我們想找出目前元素的某個父親的時候,下面的文法就要用到了。

    $(this).parents("li");//$(this).parents().find("li");
    登入後複製

    所以parents()的實用性很強。非常常用。

    parentsUntil(expr)。如果說parents()是在整個html元素中找選擇器中每個元素的所有父親,那麼parentsUntil()的作用就是限制了查找的範圍。這個範圍就是 $(expr).html()

    $("p").parents();//包含整个html 元素$("p").parentsUntil("html");//不包含整个html元素
    登入後複製

    以上兩個表達式的結果集只相差一個元素,就是整個html元素。

    $("p").parents();//包含整个html 元素$("p").parentsUntil();//包含整个html元素
    登入後複製

    當parentsUntil()不帶參數時,他等同於parents();

    parentsUntil(expr)的結果集中的結果同樣是由內層向外層排列的。 parentUntil(expr),會從第一個包裹著元素父元素開始向外逐層查找,直到遇到第一個與表達式(expr)相符的元素為止。

    $("p").parentsUntil(expr);
    登入後複製

    相當於在$(expr)中由內之外的尋找$("p")中每個元素的所有父元素

    為了更精準的尋找到指定的元素,可以如下的使用。

    $("p").parentsUntil("ul").find("li");
    登入後複製

    但以上做法不能找到ul>li,只能找到ul * li。因為paentsUntil()傳回結果集中最大的父親是ul>*而find是在ul>*的後代元素尋找不包含ul>*的元素。所以如果用該方法查找ul>li是不可行的

    可以使用以下程式碼查詢全部ul下的li(第一行),最近的ul下的所有li(第二行)

    $("p").parents("ul").find("li");$("p").parents("ul").eq(0).find("li");
    登入後複製

    parentsUntil(expr),傳回的結果集不包括expr本身,而後面如果使用find()又會在結果集後代元素中查詢,所以查詢得到的結果不是expr的子元素而是二代和二代以後的子元素。

    鑑於parentsUntil的表現,一般不建議使用。

    parnetsUntil()可用來找出某個模組下的某些元素。

    當我們要具體對結果集中某個元素進行操作是,要記得使用eq(i),first(),last()等函數取值,不然操作的是整個結果集。

    動態尋找父節點

    $(this).parent("li");//找到第一个包住$(this)的dom,如这个dom是li则返回他的对象,如果不是则返回空对象$(this).parents("li");//找到所有$(this)的父亲,并在其中找出所有的li的对象,组成结果集。结果集中结果由内之外排列$(this).parents().find("li");//同上。$(this).parents("li").eq(0);//$(this)外第一个包裹他的li对象$(this).parentsUntil("li");//$(this)外到第一个包裹他的li之内的所有的$(this)的父亲$(this).parentsUntil("ul").find("li");//$(this)在ul之前的那个父亲之内(不包括该父亲)找所有的li;如果<ul><li><p><a onclick="f()">中a是this的话,那么相当于$("li").find("li");最后结果之空。$(this).parents("li").sublings();//查找所在的li的所有同辈元素
    登入後複製

    與parent()對應的函數是children()

    與parents()對應的函數是find()

    以上是JQuery中parent(),parents(),parentsUntil()區別聯繫以及使用方法教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PS導出PDF如何設置密碼保護 PS導出PDF如何設置密碼保護 Apr 06, 2025 pm 04:45 PM

在 Photoshop 中導出帶密碼保護的 PDF:打開圖像文件。點擊“文件”&gt;“導出”&gt;“導出為 PDF”。設置“安全性”選項,兩次輸入相同的密碼。點擊“導出”生成 PDF 文件。

c語言函數的基本要求有哪些 c語言函數的基本要求有哪些 Apr 03, 2025 pm 10:06 PM

C語言函數是代碼模塊化和程序搭建的基礎。它們由聲明(函數頭)和定義(函數體)組成。 C語言默認使用值傳遞參數,但也可使用地址傳遞修改外部變量。函數可以有返回值或無返回值,返回值類型必須與聲明一致。函數命名應清晰易懂,使用駝峰或下劃線命名法。遵循單一職責原則,保持函數簡潔性,以提高可維護性和可讀性。

c語言函數的概念 c語言函數的概念 Apr 03, 2025 pm 10:09 PM

C語言函數是可重複利用的代碼塊,它接收輸入,執行操作,返回結果,可將代碼模塊化提高可複用性,降低複雜度。函數內部機制包含參數傳遞、函數執行、返回值,整個過程涉及優化如函數內聯。編寫好的函數遵循單一職責原則、參數數量少、命名規範、錯誤處理。指針與函數結合能實現更強大的功能,如修改外部變量值。函數指針將函數作為參數傳遞或存儲地址,用於實現動態調用函數。理解函數特性和技巧是編寫高效、可維護、易理解的C語言程序的關鍵。

H5和小程序與APP的區別 H5和小程序與APP的區別 Apr 06, 2025 am 10:42 AM

H5、小程序和APP的主要區別在於:技術架構:H5基於網頁技術,小程序和APP為獨立應用程序。體驗和功能:H5輕便易用,功能受限;小程序輕量級,交互性好;APP功能強大,體驗流暢。兼容性:H5跨平台兼容,小程序和APP受平台限制。開發成本:H5開發成本低,小程序中等,APP最高。適用場景:H5適合信息展示,小程序適合輕量化應用,APP適合複雜功能應用。

在router文件夾下的index.js文件中為什麼需要調用Vue.use(VueRouter)? 在router文件夾下的index.js文件中為什麼需要調用Vue.use(VueRouter)? Apr 05, 2025 pm 01:03 PM

在router文件夾下的index.js文件中註冊VueRouter的必要性在開發Vue應用程序時,常常會遇到關於路由配置的問題。特�...

c和c#的區別和聯繫有哪些 c和c#的區別和聯繫有哪些 Apr 03, 2025 pm 10:36 PM

C和C#雖有類似之處,但截然不同:C是面向過程、手動內存管理、平台依賴的語言,用於系統編程;C#是面向對象、垃圾回收、平台獨立的語言,用於桌面、Web應用和遊戲開發。

JavaScript中如何從指定DOM節點下使用XPath進行查找? JavaScript中如何從指定DOM節點下使用XPath進行查找? Apr 04, 2025 pm 11:15 PM

DOM節點下XPath查找方法詳解在JavaScript中,我們經常需要根據XPath表達式從DOM樹中查找特定的節點。如果需要從某�...

H5和小程序的推廣方式有何不同 H5和小程序的推廣方式有何不同 Apr 06, 2025 am 11:03 AM

H5與小程序的推廣方式存在差異:平台依賴性:H5依賴瀏覽器,小程序依賴特定平台(如微信)。用戶體驗:H5體驗較差,小程序提供類似原生應用的流暢體驗。傳播方式:H5通過鏈接傳播,小程序通過平台分享或搜索。 H5推廣方式:社交分享、郵件營銷、QR碼、SEO、付費廣告。小程序推廣方式:平台推廣、社交分享、線下推廣、ASO、與其他平台合作。

See all articles