在dom事件中普通函数与箭头函数this指向

为什么绑定点击事件用普通函数this指向节点本身,而用箭头函数this却指向window 

<body>
    <ul>
        <li>芜湖</li>
        <li>起飞</li>
        <li>全体起立</li>
        <li>开始码!</li>
    </ul>
    <script>
        let lis = document.querySelectorAll("li");
        for (let i = 0; i < lis.length; i++) {

            lis[i].onclick = function() {
                console.log(this); // 指向li节点
            }

            lis[i].onclick = () => {
                console.log(this); // 指向window
            }
        }
    </script>
</body>

 

首先什么是 this

this 是函数在运行时,函数体内部自动生成的一个对象,只能在函数体内部使用。

this 又是指向运行时调用者,就是说代码有无数种可能,别人也不容易理解。所有出了箭头函数

箭头函数没有this,内部不生成对象。只会找自己作用域链上级,继承this。纯函数存在。

回答
你的问题,箭头函数指向了window,现在我们知道箭头函数内部没有this,找自己作用域链的上级this,上级是dom,运行dom的是window,所以this就是window

https://blog.csdn.net/qaz1128123/article/details/117930624?spm=1001.2014.3001.5502

1.普通函数的this:指向它的调用者,如果没有调用者则默认指向window.
2.箭头函数的this: 指向箭头函数定义时所处的对象,而不是箭头函数使用时所在的对象,默认使用父级的this.

3.箭头函数中的this,首先从它的父级作用域中找,如果父级作用域还是箭头函数,再网上找,如此直至找到this的指向

“箭头函数的this: 指向箭头函数定义时所处的对象,而不是箭头函数使用时所在的对象”

那这段代码中箭头函数是在for循环里定义的,所以这个箭头函数的父级是for循环吗?