首页 > 其他分享 >this的指向

this的指向

时间:2022-11-14 09:35:53浏览次数:43  
标签:console 函数 指向 对象 按钮 apply

一、this的指向分类

分类 this指向
普通函数 window
构造函数 实例对象,原型对象里面的方法也指向实例对象
对象方法 该方法所属对象。若对象中的方法为普通函数写法吗,则this指向该方法所属对象,若为箭头函数,则this指向为window
事件绑定函数 绑定事件对象
定时器 window
立即执行函数 window
箭头函数 外层作用域中的this(且this指向不可改变)

二、改变函数内部this指向

1.函数名称.call(this要指向的,传递的参数1,...)
  • 调用函数,并改变this指向。

    var obj = {
        name: 'zs',
        age: 18
    }
    function fn (a, b) {
        console.log(this)	// this指向obj这个对象
        console.log(a + b)	// 6
    }
    fn.call(obj, 1, 5)
    
2.函数名.apply(this要指向的,[传递的参数1,...])
  • 调用函数,并改变this指向,传递的参数必须是数组。

    var arr = [1, 88, 0, 34, 171, 23]
    // 利用apply传递数组(伪数组),借助数学内置对象求数组最大值/最小值
    var max = Math.max.apply(Math, arr)
    console.log(max)	// 171
    var min = Math.min.apply(Math, arr)
    console.log(min)	// 0
    
3.函数名.bind(this要指向的,传递的参数1,...)
  • 不调用函数,但改变this指向,调用需要fn.bind(...)( )。

    <button>按钮1</button>
    <button>按钮2</button>
    <button>按钮3</button>
    <script>
    	// 获取所有的按钮元素
        let btns = document.querySelectorAll('button')
        for (let i = 0; i < btns.length; i++) {
            btns[i].addEventListener('click', function () {
                // 点击后禁用按钮
                this.disabled = true
                setTimeout(function () {
                    // 2秒后解除禁用该按钮
                    this.disable = false
                }.bind(this), 2000)
            })
        }
    </script>
    

标签:console,函数,指向,对象,按钮,apply
From: https://www.cnblogs.com/P1Kaj1uu/p/16888025.html

相关文章

  • <六>指向类成员的指针
    指向类成员(成员变量和成员方法)的指针1:定义一个指针指向类的普通成员变量示例代码1点击查看代码classTest2{public:intma;staticintmb;voidf1()......
  • 在 SAP Fiori Gateway 系统配置一个指向 SAPGUI 事务的 tile
    对于应用程序类型Transaction、WebDynpro和URL,开发人员可以直接在SAPFioriLaunchpadDesigner的目标映射中定义系统别名。目标映射配置中的参数SystemAlias表......
  • 在 SAP Fiori Gateway 系统配置一个指向 SAPGUI 事务的 tile
    对于应用程序类型Transaction、WebDynpro和URL,开发人员可以直接在SAPFioriLaunchpadDesigner的目标映射中定义系统别名。目标映射配置中的参数SystemAlias表示......
  • 改变this的指向
    this概述:this是一个特殊的对象,他类似于一个指针会指向对应的对象。(在对象的函数内那么对应的this就指向这个对象,在外面的函数内this就指向最顶层的对象window)。this指向当......
  • javascript基础 this指向
    this指向:this永远指向一个对象;this的指向完全取决于函数调用的位置;场景1:在全局环境中调用,this指向window对象vara='a'functionfoo(){console.log(this.a)......
  • [JavaScript-10]this指向
    1.默认绑定//全局环境指向windowconsole.log(this);//函数独立调用,函数内部this指向windowfunctionfn(){console.log(this);}fn();//函数当做对象方法......
  • 【面试题】说说JS中的this指向问题
    JS中的this指向问题this的指向问题全局作用域在JS中,全局的变量和函数附着在​​global​​​对象上,全局对象在浏览器环境下是​​window​​对象。在全局作用域中,​​this​......
  • 如何确定 this 指向?改变 this 指向的方式有哪些?
    this指向:1.全局上下文(函数外)无论是否为严格模式,均指向全局对象。注意:严格模式下全局对象为undifined2.函数上下文(函数内)默认的,指向函数的调用对象,且是最直接的调......
  • JS 探索 this 指向问题
    1.扑朔迷离的this从表面来看,this总能通过各种变通的方式得到意想不到的结果既然是“意想不到”,就说明对“各种变通的方式”不太了解2.那么我们来看看“各种变......
  • JS中的this指向问题
    this的指向问题全局作用域在JS中,全局的变量和函数附着在global对象上,全局对象在浏览器环境下是window对象。在全局作用域中,this指向全局对象window。console.log(thi......