javascript - jquery事件绑定中的this指向问题
问题描述
代码如下:
$(function(){$.ajax({ type:'GET', url:'/msg', success:function(data){var html='';for(var o of data){ html+=`<tr> <td>${o.mid}</td> <td>${o.uname}</td> <td>${o.content}</td> <td>${o.pubtime}</td> <td><a href='https://www.haobala.com/wenda/${o.mid}'>删除</a> </th></tr> `;}$('#tb1').html(html); }});$('#tb1').on('click','a.btn-del',(e)=>{ e.preventDefault(); //var mid=this.getAttribute('href'); console.log(this);}); });
我需要给异步请求生成的a.btn-del绑定删除事件,需要获取当前点击元素的herf属性值;通过e.target可以或得;但是通过this,不可以。console.log(this)后 ,输出#document.
难道事件代理中this不是指向当前点击的元素吗??
问题解答
回答1:你把 (e)=> {} 改成 function(e){} 看看。
你应该先去了解下this的绑定机制。
箭头函数中this是指向外层函数作用域。
回答2:下面是js函数调用的几种方式:
var func = function(a,b){ console.log(this); console.log(a + ’ ’ + b)};var self = ’test’;func(1,2); // this 是 window 对象, 因为此时调用函数的是window对象func.call(self,1,2); // this是 字符串 ’test’func.apply(self,[1,2]); // this是 字符串 ’test’
js不是面向对象的语言,跟java比, 在实现面向对象上,语法上面是会有些奇怪。如果是以 func() 的方式调用函数, 则this的值取决于调用函数的是在哪个对象。在设置回调函数时,如果没有传this参数, 就是 func()的调用方式,一般的写法应该是用另外一个变量来保存this的值, 通常变量名为self。
var self = this;XXXX.callback = function(){ console.log(self);};回答3:
如果要调用jq的方法,应该使用$(this)才代表的是jq对象
回答4:获取href : this.hash
相关文章:
1. html5和Flash对抗是什么情况?2. mysql - 关于时间的入库问题,大神们你们存数据库的时间是取本地的时间,还是取utc的时间?3. apache - 本地搭建wordpress权限问题4. node.js - hexo+github搭建博客建站时出现问题5. 在mac下出现了两个docker环境6. javascript - 从mysql获取json数据,前端怎么处理转换解析json类型7. java - 静态属性中的赋值和静态代码块中的赋值有什么区别?8. javascript - 开发者工具中的本地缓存放在电脑的哪个文件夹9. css3 - 在sublime text里, 如何让emmet生成的带前缀css属性垂直对齐?10. 数据库无法进入
