javascript - 關于JS 事件委托操作ul li標簽的問題
問題描述
先說一下我想要實現的功能,就是在一個ul 里面 點擊某個li標簽 就移除當前點擊的li。
但是搞來搞去就是沒能實現我想要的效果。
現在的問題如下
怎么用更直接的方法取得當前點擊的li下標,for循環取下標是百度淘來的。
移除是可以用了,但是它不是按我點擊的li移除 比如我點擊2 它會刪除3 or 4 不知道是不是if(e.target == children[i])這里判斷不對
點擊一次沒效果,要點第二次才執行removeChild。
HTML結構
<ul id='box'> <li data='2017'>0</li> <li>1</li> <li>2</li> <li>3</li> <li>4</li></ul>
JS代碼
document.getElementById('box').addEventListener('click',function(e) { if(e.target && e.target.nodeName == 'LI') {var children = this.children; //獲取ul里面的所有li元素集合for(var i=0;i<children.length;i++){ if(e.target == children[i]) { //對比目標元素和li集合元素//alert('目標元素的下標為:' + i); //輸出目標元素的下標 document.getElementById(e.target.parentNode.id).removeChild(document.getElementById(e.target.parentNode.id).childNodes[i]);return; }} }});
問題解答
回答1:document.querySelector(’#box’).addEventListener(’click’,function(e){ if(e.target.nodeName=='LI'){e.target.parentNode.removeChild(e.target); }});回答2:
<!DOCTYPE HTML><html><ul id='box'> <li data='2017' onclick='removeli(this);'>0</li> <li onclick='removeli(this);'>1</li> <li onclick='removeli(this);'>2</li> <li onclick='removeli(this);'>3</li> <li onclick='removeli(this);'>4</li></ul><script>function removeli(node){node.parentNode.removeChild(node);}</script></html>
相關文章:
1. 查詢mysql數據庫中指定表指定日期的數據?有詳細2. mysql - 怎么生成這個sql表?3. mysql儲存json錯誤4. php - 公眾號文章底部的小程序二維碼如何統計?5. mysql - 表名稱前綴到底有啥用?6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?8. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?9. mysql - 數據庫建字段,默認值空和empty string有什么區別 11010. sql語句 - 如何在mysql中批量添加用戶?
