关于js remove的问题 求问出了什么问题

hevi2009 2018-03-19 10:32:31
var list =document.getElementsByClassName('prove');
for(var i=0;i<list.length;i++){
list[i].index=i;
list[i].onclick=function () {
var inde=this.index;
alert(inde);
console.log(list[inde]);
var re=list[inde];
list.remove(re);
}
}

报错如下图

...全文
944 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
东明之羞 2018-05-09
  • 打赏
  • 举报
回复
var list =document.getElementsByClassName('prove');  
    for(var i=0;i<list.length;i++){  
        list[i].index=i;  
        list[i].onclick=function () {  
           var inde=this.index;
           alert(inde);
           console.log(list[inde]);
           var re=list[inde];
           list.remove(re);
        }   
    }  
你的list变量在当前的onclick函数中是不存在的, 你可以尝试修改onclick方法为
  list[i].onclick=(function () { 
		return function(){
			   var inde=this.index;
			   alert(inde);
			   console.log(list[inde]);
			   var re=list[inde];
			   list.remove(re);
		   }
        })(list);  
风中的少年 2018-05-02
  • 打赏
  • 举报
回复
能换成JQuery就换成jquery吧。 免得到时可能会存在浏览器的兼容问题。
天际的海浪 2018-05-02
  • 打赏
  • 举报
回复
你这个都是原生js代码,而remove是jquery的方法。 要使用remove,先引入jquery库。 $(re).remove(); 或者用原生Dom对象的移除方法 re.parentNode.removeChild(re);
rookienewbiewang 2018-04-28
  • 打赏
  • 举报
回复
list 是一个元素数组 , remove 方法 调用方式为 元素.remove(),而且记住删除元素的时候会把自己也删除了哦
似梦飞花 2018-03-19
  • 打赏
  • 举报
回复
removeChild是parentNode.reomveChild(li) 改成this.parentNode.removeChild(this)试试
zhangfei2211 2018-03-19
  • 打赏
  • 举报
回复
普通的javascript的remove方法和jquery的remove方法的用法是不一样的

87,910

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧