可以看出parent的取值很明確,就是目前元素的父元素;parents則是目前元素的祖先元素。以下列出範例說明:
<p id='p1'> <p id='p2'><p></p></p> <p id='p3' class='a'><p></p></p> <p id='p4'><p></p></p> </p>
$('p').parent()取到的是p2,p3,p4
$('p').parent('.a ')取到的是p3
$('p').parent().parent()取到的是p1,這點比較奇特;不過Jquery物件本身的特點決定了這是可行的。
$('p').parents()取到的是p1,p2,p3,p4
$('p').parents('.a')取到的是p3
parent (exp)用法:取得一個包含著所有符合元素的唯一父元素的元素集合。
<script src="jquery-1.2.6.min.js" type="text/javascript"></script> <script type="text/javascript"> $(document).ready(function() { $("#btn1").click(function(){ alert($(this).parent().next().html()); }); }); </script> </head> <body> <table> <tr> <td><input id="btn1" class="btn" type="button" value="test" /></td> <td>some text</td> </tr> </table>
其中:
this.parent()是input前面的td
this.parent().parent()取得的是tr
this.parent().parent() .parent()取得的是table
this.parent().next()取得的是td相臨的td
範例:
<p><p>Hello</p><p>Hello</p></p>
$("p") .parent() 得到的是:e388a4556c0f65e1904146cc1a846beee388a4556c0f65e1904146cc1a846beeHello94b3e26ee717c64999d7867364b1b4a3e388a4556c0f65e1904146cc1a846beeHello94b3e26ee717c64999d7867364b1b4a394b3e26ee717c64999d7867364b1b4a3對象,因為p標籤的父標籤是p
#jquery的parents()使用
今天遇到一個有意思的問題,jquery有兩個函數parent()和parents().透過這兩個函數可以找到一個物件的父對象,又稱作jquery的選擇器。舉個例子:
<body> <div id="one"> <div id="two">hello</div> <div id="three"> <p> <a href="#">tonsh</a> </p> </div> </div>
$(”a”).parent()將會得到父物件e388a4556c0f65e1904146cc1a846bee
$(”a”).parents()得到父物件為00cdd74976f45d3c7ac132ec48f75e9bdd1ad21d926ab3d81e0b74863b822d1b
$(”a”).parents().filter(”div”)將得到dc0c0bf950c16358990a944092168089dd1ad21d926ab3d81e0b74863b822d1b,還可以寫成$(”a”).parents(”div”)。
如果想的到0d2b8ff6d648b89a944975f20a7117fa物件可以寫成這樣:$(”a”).parents(”div:eq(0)”)。
如果點擊3499910bf9dac5ae3c52d5ede7383485連結時彈出0d2b8ff6d648b89a944975f20a7117fa中的內容該怎麼辦?
var id=$("a").parents("div:eq(1)").children("div:eq(0)").html(); alert(id);
以上是jquery中關於parent和parents兩者的差異分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!