国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

javascript - 問一下關于JS中this的問題。

瀏覽:122日期:2023-03-18 17:26:04

問題描述

為什么這個地方onclick事件沒有被觸發?如果是jquery中這樣可以得到當前點擊的這個li的dom對象,那JS種不能這樣使用嗎?

$(document).ready(function(){ $('ul li').click(function(){console.log($(this));//打印出當前被點擊的li的jquery對象console.log(this);//打印出當前被點擊的li的dom對象 });});

window.onload = function(){ var lis = document.getElementsByTagName('li'); lis.onclick = function(){console.log('111');console.log(this); }}

修改:

window.onload = function(){ var lis = document.getElementsByTagName('li'); Array.from(lis).forEach(function(el) {console.log('111');console.log(this); })}

<p> <ul><li></li><li></li><li></li> </ul></p>

謝謝各位,之前都用jquery,現在重新看看js發現了很多問題。這種低級錯誤以后不會再犯了,印象深刻 ^_^ 。

問題解答

回答1:

javascript - 問一下關于JS中this的問題。

能把 你有點擊觸發這個事件么? 我在 segmentFault 可以用。

不過你代碼有點小問題 getElementsByTagName 返回的是一個類數組對象

javascript - 問一下關于JS中this的問題。

應該遍歷他 然后把給每個元素的 onclick 賦值

回答2:

不是 this 的原因。

onclick 是 DOM 的事件。但是此時的 lis 根本就不是 dom,而是 DOM 的集合。

jQuery 之所以可以處理,是因為 $('ul li') 返回的是 jQuery 對象,當在其上面調用 click 函數時,jQuery 會隱式的使用循環。

雖然 lis 很像數組,但是卻不是數組。因此可以使用 Array.from 函數把它變成真正的數組。

window.onload = function(){ var lis = document.getElementsByTagName('li'); Array.from(lis).forEach(function(el) {console.log('111');console.log(this); })}回答3:

lis = document.getElementsByTagName('li')得到的是一個數組。你應該如何綁定事件呢?javascript - 問一下關于JS中this的問題。

回答4:

試試不要用.onclick()寫點擊事件;用addEventListener(’click’,function(){console.log(this)});添加點擊事件看看能不能觸發,我懷疑是因為你拿到lis是一個數組 onclick是不是因為這個原因不行了

回答5:

第二段代碼寫的不對, lis 是一個數組,不是 dom 對象,所以設置 onclick 沒用改成這樣

window.onload = function(){ var lis = document.getElementsByTagName('li'); Array.from(lis).forEach((li) => {li.onclick = function(){ console.log('111'); console.log(this);} })}回答6:

直接用getElementsByClassName這個方法吧,把getElementsByTagName封裝了一下可以作為dom操作

function getElementsByClassName(oElm, strTagName, strClassName){ var arrElements = (strTagName == '*' && oElm.all)? oElm.all :oElm.getElementsByTagName(strTagName); var arrReturnElements = new Array(); strClassName = strClassName.replace(/-/g, '-'); var oRegExp = new RegExp('(^|s)' + strClassName + '(s|$)'); var oElement; for(var i=0; i < arrElements.length; i++){oElement = arrElements[i];if(oRegExp.test(oElement.className)){ arrReturnElements.push(oElement);} } return (arrReturnElements)}回答7:

javascript - 問一下關于JS中this的問題。如上圖,你的lis打印出來是一個對象數組,按照你的思路你應該遍歷lis去為每個li對象綁定onclick

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 91欧美激情一区二区三区成人 | 亚洲欧洲国产视频 | 美国免费三片在线观看 | 成人免费一级毛片在线播放视频 | 91成人在线免费视频 | 亚洲一区二区三区福利在线 | 长腿校花被啪到腿软视频 | 91伦理视频 | 国产三级做爰高清视频a | 国产黄色小视频 | 欧美成人私人视频88在线观看 | 免费人成黄页在线观看视频国产 | 久久成人精品视频 | 尹人在线视频 | 午夜伦4480yy妇女久久久 | 欧美黄成人免费网站大全 | 成人精品综合免费视频 | 国产欧美日韩在线观看 | 91寡妇天天综合久久影院 | 韩国一级片在线观看 | 免费一级成人毛片 | 99视频有精品 | 美女张开腿黄网站免费 | 国产三级a三级三级 | 国产精品极品美女自在线看免费一区二区 | 400部大量精品情侣网站 | 久久99精品久久久久久三级 | 国产精品va一级二级三级 | 欧洲97色综合成人网 | 欧美性xxxx18| 久久精品视频大全 | 亚洲免费视频观看 | 久久久久久久99久久久毒国产 | 欧美精品亚洲精品日韩专区 | 欧美激情亚洲一区中文字幕 | 成人看片黄a免费 | 成年女人免费视频播放成年m | 国产成人精品.一二区 | 亚洲性网| 精品国产综合区久久久久久 | 成人涩涩屋福利视频 |