【JS重点19】this指向问题总结

2024-06-18 15:28
文章标签 问题 总结 js 重点 指向 19

本文主要是介绍【JS重点19】this指向问题总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一:普通函数this指向

普通函数在严格模式下:

二:箭头函数this指向

this指向说明

不适用this情况

三:改变this指向

1 call()

语法格式:

作用:

2 apply()

语法格式:

作用:

使用场景:

3 bind()方法

作用:

应用场景:

四:如何赚钱


阅读本文章目标:够知道this在不同环境下的默认值,知道动态指定函数this值的方法

一:普通函数this指向

普通函数的调用方式决定了this的值,即谁调用普通函数,this就指向谁

 setTimeout(function () {console.log(this);//window}, 1000)
}
//以及setInterval都是指向window,因为其完整的写法是window.setInterval、window.setTimeout

普通函数在严格模式下:

    function fn() {console.log(this);//undefined}fn()

对于在严格模式下,如果没有写清楚普通函数的调用者,this返回undefined

二:箭头函数this指向

this指向说明

箭头函数中本身不存在this,其this是沿着作用域链查找;直到找到外层作用域中有this指向的部分,沿用它的this指向

不适用this情况

构造函数、原型函数(因为在普通函数中,构造函数、原型函数指向实例对象,有其特殊的作用)DOM事件中的函数(指向函数的调用者)

因此要在合适的环境下,合理的使用this0

三:改变this指向

JS中允许指定函数中this的指向,以下3个方法可以动态指定普通函数中this的指向

1 call()

语法格式:

函数名.call(this指向,参数1,参数2....)

作用:

  1. 可以调用函数,并传参
  2. 指定this的指向
const obj = {uname: "郭富城"}function fn(x, y) {console.log(this);//objconsole.log(x + y);//3}fn.call(obj, 1, 2)

2 apply()

语法格式:

fun.apply(this的指向,[传递的值])
//与call()方法的区别:
//应用apply时,向函数内传递参数,必须将传递的值包含在数组当中

作用:

同call()方法

使用场景:

求数组最大最小值

const arr = [1, 3, 4, 5]const max = Math.max.apply(Math, arr)const min = Math.min.apply(Math, arr)console.log(max, min);//5 1
//因为apply可以调用参数,所以用这种方式调用Math对象中的max以及min方法

3 bind()方法

作用:

  • 不会调用函数
  • 其返回值为修改this指向的函数
  • 返回函数中的this指向,已经被指定过了
    const obj = {uname: "郭富城"}function fn(x, y) {console.log(this);//objconsole.log(x + y);//3}const fun = fn.bind(obj, 1, 2)fun()

应用场景:

不用调用函数,但是还想改变this指向,比如改变定时器内部this指向

需求:有一个按钮,点击里面就禁用,2秒后开启

 const btn = document.querySelector('button')btn.addEventListener('click', function () {this.disabled = truesetTimeout(function () {this.disabled = false}.bind(btn/this), 2000)})

四:如何赚钱

现在是否厌倦了程序员朝九晚五的生活,想给自己生活寻找另一条路径;在校大学生是否愿意在校进行人生中的第一次创业,获取人生第一桶金;是否正在看此篇文章的你愿意通过五年努力,让自己开上梦想的中的车子;

那就从提升认知开始,加入微木的知识星球:微木的创业思考

专属于创业者的交流集中地,创业、认知提升找微木!

1 创业底层方法论

2 从千万本书书籍中挑选出的,人生必读书目清单。

3 认知提升学习资源(秘密)

4 寻找赚钱项目底层方法论

5 好书精华提炼

6 深度链接微木

每天仅需0.3元/天,欢迎加入专属于创业者的交流集中地,创业、认知提升找微木!

这篇关于【JS重点19】this指向问题总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1072382

相关文章

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

解决Nginx启动报错Job for nginx.service failed because the control process exited with error code问题

《解决Nginx启动报错Jobfornginx.servicefailedbecausethecontrolprocessexitedwitherrorcode问题》Nginx启... 目录一、报错如下二、解决原因三、解决方式总结一、报错如下Job for nginx.service failed bec

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十