JavaScript 封装兼容的事件注册函数(call()改变this的指向)

本文探讨了如何在JavaScript中封装一个兼容的事件注册函数,并利用call()方法来改变函数执行时的上下文(this)指向。通过示例代码,展示了在不同场景下事件处理函数的正确绑定和调用。
摘要由CSDN通过智能技术生成


demo.html:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        div{
            width: 200px;
            height: 200px;
            background-color: pink;
            border:10px dashed lightgreen;
        }
    </style>
    <script>

        //1、三种注册事件方式的处理函数中(handler函数)的this指向不一致
        //使用addEventListener的方式注册的点击事件的回调函数中的this 指向target
        //但是使用attachEvent的方式注册点击事件的回调函数中的this 指向window

        //2、3种注册事件方式中,回调函数内获取事件对象的方式也是不一致的(高版本通过形参直接获取event,低版本通过window.event获取)
        //要让他们统一,
        //在第二种的事件注册方式(attachEvent)中,手动给handler传递window.event

        function createEventRegister(){
            if(window.addEventListener){  //第一种方式
                return function(target, type, handler
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值