this指向详解

目录

一:严格模式与非严格模式

1.严格模式的开启

2.this指向的一些情况:

二:如何指定this的值?

1.在调用时指定this的值

2.在创建时指定this的值

[​编辑三: 结尾](#编辑三: 结尾)

一:严格模式与非严格模式

在非严格模式下,总是指向一个对象,在严格模式下可以是任意的值。

1.严格模式的开启

在我们的日常开发中,所使用的一般都是非严格模式。如果要使用严格模式可以添加 use strict 代码。

注意:这一行代码不管是写在方法里还是全局,都要写在最上方,可以有注释,但是不能有别的代码。

2.this指向的一些情况:

1) 全局执行环境中,指向全局对象(无论是严格模式下还是非严格模式下)

javascript 复制代码
    <script>
        'use strict'
        console.log(this)
    </script>

这里是开启了严格模式的,但是其实非严格模式也是指向的Window

2) 函数内部,取决于函数被调用的方式

(1)直接调用的this值

非严格模式下:全局对象(window)

严格模式下:undefined

javascript 复制代码
        // ----函数内部----
        //  直接调用-非严格模式
        function func(){
            console.log(this);
        }
        //  直接调用--严格模式
        function func_script(){
            'use strict'
            console.log(this);
        }
        func()
        func_script()

(2)对象方法调用的this值:调用者(两种模式都是)

javascript 复制代码
        //-----3. 对象方法调用 -----
        'use strict'
        const person = {
            name:'张三',
            out(){
                console.log(this);
            }
        }
        person.out()

这里写了严格模式,非严格模式下也是指向的调用者(person)

二:如何指定this的值?

1.在调用时指定this的值

call方法:func.call(thisArg,参数1,参数2....)

apply方法:func.apply(thisArg,[参数1,参数2....])

javascript 复制代码
        // ------1. 调用时指定this的值 ------
        function func(numA,numB){
            console.log(this);
            console.log(numA,numB);
        }
        const person = {
            name:'张三'
        }
        // 1.1  call方法
        func.call(person,1,2)
        // 1.2 apply方法-以数组的方式传入参数
        func.apply(person,[3,4])

可以看到,这里的 this 指向被我们主动改变,变成了指向person对象。否则的话,这里的this应当是指向Window。

2.在创建时指定this的值

bind方法:const bindFunc = func.bind(thisArg,绑定参数1,绑定参数2....)

箭头函数:() => {console.log(this)} 注意:这里的this找的是上级函数的this

javascript 复制代码
        function func(numA,numB){
            console.log(this);
            console.log(numA,numB);
        }
        const person = {
            name:'张三'
        }


        // ------2. 调用时指定this的值 ------
        // // 2.1  bind方法
        const bindFunc =  func.bind(person,'bind方法第一个参数')
        bindFunc('第二个参数')
        // // 2.2  箭头函数
        const food = {
            name:'蛋包饭',
            eat(){
                console.log(this);
                //这里是箭头函数,所以是上级作用域的对象,所以是food
                setTimeout(() => {
                    console.log(this);
                }, 1000);
                // 下面不是箭头函数,所以是全局对象window
                // setTimeout(function(){
                //     console.log(this);
                // }, 1000);
            }
        }
        food.eat()

三: 结尾

this是开发过程中最为常用的,因此掌握好this的指向,是一个开发工程师所必不可少的,同时可以减少很多莫名其妙的Bug,后续会完善一些call,apply,bind的手写方法,有想法的小伙伴可以一起来学习哦!

相关推荐
鹿角片ljp几秒前
Java多线程编程:从基础到实战的完整指南
java·开发语言·后端
ggaofeng2 分钟前
理解npm的原理
前端·npm·node.js
摘星编程4 分钟前
React Native for OpenHarmony 实战:SnapCarousel 轮播组件详解
javascript·react native·react.js
超级无敌大学霸6 分钟前
c语言算术转换及表达式解析
c语言·开发语言
电商API_180079052477 分钟前
1688商品详情采集API全解析:技术原理、实操指南与业务落地
大数据·前端·人工智能·网络爬虫
記億揺晃着的那天7 分钟前
Chrome 自动填充“用户名”到普通输入框 - 解决方案
前端·chrome
努力学习的小廉11 分钟前
【QT(八)】—— 常用控件(五)
开发语言·qt
期待のcode11 分钟前
Java虚拟机的垃圾回收器
java·开发语言·jvm·算法
星火开发设计15 分钟前
C++ 分支结构:if-else 与 switch-case 的用法与区别
开发语言·c++·学习·算法·switch·知识·分支
qq_4061761418 分钟前
深耕JS防抖与节流:从原理到工程化实践的全方位指南
开发语言·php