亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

關于選定當前元素的直接祖先元素問題

<ul?id="menu">
????<li?id='1002'>根目錄1
????????<ul?class="sub_menu"?id='sub_1002'?style="display:none">
????????????<li>子目錄1-1</li>
????????????<li>子目錄1-2</li>
????????</ul>
????</li>
????<li?id='1221'>根目錄2
????????<ul?class="sub_menu"?id='sub_1221'?style="display:none">
????????????<li>子目錄2-1</li>
????????????<li>子目錄2-2</li>
????????</ul>????
????</li>
????<li?id='1232'>根目錄3
????????<ul?class="sub_menu"?id='sub_1232'?style="display:none">
????????????<li?class='current'>子目錄3-1</li>
????????????<li>子目錄3-2</li>
????????</ul>
????</li>
</ul>

這是一個二級菜單,當前位置是根目錄3下面的子目錄3-1其屬性為current,現在想選擇當前子目錄3-1所在的<ul>元素,將其取消隱藏;再選擇當前子目錄3-1所在的上一級目錄“根目錄3”的<li>元素,并添加其屬性改為"menuon",我的代碼如下:

<script>
????$(".sub_menu?li[class='current']").parent().show();
????$(".sub_menu?li[class='current']").parents().addClass("menuon");
</script>

結果是所有隱藏的二級目錄全部顯示出來了,根目錄3也沒有添加menuon屬性。

請教各位,怎么樣才能只選擇當前元素的直接上級元素,而不是遍歷所有上級同類元素。我想利用id來精確選擇某一個上級元素,但是不知道怎么表達出來。

正在回答

1 回答

$(".current").parent(".sub_menu").show();

$(".current").parent("#1232").addClass("menuon");

0 回復 有任何疑惑可以回復我~
#1

a_yong 提問者

謝謝熱心解答。不過$(".current").parent(".sub_menu").show()會將上一級所有class='sub_menu'的ul選擇出來,$(".current").parent("#1232").addClass("menuon")能實現功能,但是后臺代碼中不能直接指定#1232這個id,因為id是個變量。 我后來找到一個方法,那就是用closest(),$(".current").closest(".sub_menu").show()就只是將當前所在的子菜單的上一級菜單顯示出來。 感謝。
2016-04-14 回復 有任何疑惑可以回復我~
#2

a_yong 提問者

盡管沒完全實現功能,還是采納吧。
2016-04-14 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

關于選定當前元素的直接祖先元素問題

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號