javascript - Ask a question about this in JS.
滿天的星座
滿天的星座 2017-07-05 10:49:51
0
7
841

Why is the onclick event not triggered in this place? If you can get the DOM object of the currently clicked li in jquery, can't it be used in JS like this?

$(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);
    }
}

Revise:

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>

Thank you everyone. I used jquery before, but now I have found many problems when I look at js again. I won’t make this kind of stupid mistake again in the future, I’m very impressed ^_^.

滿天的星座
滿天的星座

reply all(7)
滿天的星座

Can you click to trigger this event? I can use segmentFault.


But there is a slight problem with your code. getElementsByTagName returns an array-like object

You should traverse it and then assign the onclick value to each element

大家讲道理

is not the reason for this.

onclick is a DOM event. But at this time lis is not dom at all, but a collection of DOM.

jQuery can handle it because $("ul li") returns a jQuery object. When the click function is called on it, jQuery will implicitly use a loop.

Although lis looks like an array, it is not an array. So you can use the Array.from function to turn it into a real array.

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

lis = document.getElementsByTagName("li") gets an array.
How should you bind events?

阿神

Try not to use .onclick() to write the click event; use addEventListener('click', function(){console.log(this)}); add the click event and see if it can be triggered. I suspect it is because you got lis Is onclick an array not working for this reason?

为情所困

The second piece of code is written incorrectly. lis is an array, not a dom object, so setting onclick is useless
Change it to this

window.onload = function(){
    var lis = document.getElementsByTagName("li");
    Array.from(lis).forEach((li) => {
        li.onclick = function(){
            console.log("111");
            console.log(this);
        }
    })
}
为情所困

Use the method getElementsByClassName directly, encapsulate getElementsByTagName and it can be used as dom operation

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)
}
淡淡烟草味


As shown in the picture above, your lis is printed as an array of objects. According to your idea, you should traverse lis to bind onclick to each li object

Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template