[英]Why jQuery selector can't work but getElementById works in this scenario?
[英]Why jQuery :not selector attribute doesn't work for this scenario?
我有以下代碼按預期工作:
第一種方法
$('ul').on('click', function(e) { $(this).append('<li>foo</li>'); }) .on('click', 'li', function(e) { e.stopPropagation(); });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script> <ul> <li>A</li> <li>B</li> <li>C</li> </ul>
我很酷,這就是我想要的行為。 使用這種方法似乎項目符號不是 li 元素的一部分,因為對項目符號執行的任何點擊都不會通過第二個函數。
在我認為可以稍微重構 javascript 代碼,在第一次調用中將“:not(li)”選擇器作為參數傳遞給它之后,我的問題就出現了。
第二種方法:
$('ul').on('click', ":not(li)", function(e) { $(this).append('<li>foo</li>'); });
但事實證明,行為有所不同,我不明白為什么在單擊項目符號后不添加 li 元素。
第二種方法看起來更干凈,但與我們在第一種方法中看到的相反,就像項目符號點是 li 元素的一部分。
- 為什么第二種方法表現不同?
這是因為ul :not(li)
將選擇不是li
元素的ul
任何后代。
由於您的ul
元素僅包含li
元素,因此該事件永遠不會被觸發。 但是,如果li
元素包含span
元素,則在單擊span
元素時會觸發該事件,但這不是預期的結果。
與其在單擊li
元素時抑制該事件,不如建議檢查this
是否等於e.target
。 這類似於您的第一個示例。
$('ul').on('click', function(e) { if (this === e.target) { $(this).append('<li>foo</li>'); } });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script> <ul> <li>A</li> <li>B</li> <li>C</li> </ul>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.