av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

javascript - jquery事件綁定中的this指向問題

瀏覽:99日期:2023-05-17 08:56:23

問題描述

代碼如下:

$(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='http://www.4tl426be.cn/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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 日本天天操 | 神马香蕉久久 | 日韩黄色在线视频 | 看毛片视频 | 两性免费视频 | 成人午夜在线视频 | 黄片毛片在线观看 | 国产天堂网 | www.一区二区三区 | 亚洲在线视频 | 国产乱码精品一区二区三 | 中文字幕免费在线观看 | 免费在线观看黄 | 成人在线观看视频网站 | 性av在线 | 91综合在线 | 天天操狠狠操 | 久久免费看视频 | 国产高清一区二区三区 | 日韩精品久久久久 | 亚洲国产精品久久久 | www.四虎在线| 毛片毛片毛片毛片毛片 | 国产农村妇女aaaaa视频 | 欧美久久久久久 | 极品白嫩少妇无套内谢 | 国产福利91 | 天天狠狠 | 色综合av| 日韩激情网站 | 青青草国产成人av片免费 | 国产一区二区三区 | 国产美女久久 | 国产深夜福利 | 色播五月婷婷 | 国产成人精品一区二区三区视频 | 六月婷婷在线 | a在线免费观看 | 黄a视频 | 成人少妇影院yyyy | 国产一区二区三区在线视频 |