JavaScript中改变this指向的方法【总结】- 【各自主要应用场景】

本文详细介绍了JavaScript中的`this`关键字、`apply()`、`call()`和`bind()`方法的用法,以及它们如何改变函数的上下文。通过实例演示,展示了这些方法在实现继承和数组操作中的运用。作者分享了自己多年前端开发的经验,鼓励读者系统学习以提升技能。
摘要由CSDN通过智能技术生成
  • thisArg:指向谁

  • arg1:参数1

  • arg2:参数2

1.2 应用


  • 改变this指向

let o = {

name:‘Andy’

}

function fn(a,b) {

console.log(this); //o

console.log(a+b); // 3

}

fn.call(o,1,2)

  • 实现继承

//call 可以实现继承

function Father(uname,age,sex) {

this.uname = uname;

this.age = age;

this.sex = sex

}

function Son(uname,age,sex) {

Father.call(this,uname,age,sex)

}

let son = new Son(‘小明’,16,‘男’)

console.log(son); // Son {uname: ‘小明’, age: 16, sex: ‘男’}

2. apply方法

==============================================================================

apply()方法调用一个函数。简单理解为调用函数的方式,它和call方法一样也可以改变函数的this指向。

2.1 写法


fun.apply(thisArg, [argsArray])

  • thisArg:指向谁

  • argArray:传递的值,必须包含在数组里面

  • 返回值就是函数的返回值,因为它就是调用函数

2.2 应用


  • 改变this指向

let o = {

name:‘Andy’

}

function fn(arr) {

console.log(this); //o

console.log(arr); //‘apple’ , 如果传入的是数组包含着字符串,那么会将数组去掉

}

fn.apply(o,[‘apple’])

  • 用apply借助借助于数学内置函数对象求数组中的最大值或最小值等

//我们可以用apply借助于数学内置函数对象求数组中的最大值或最小值等

//Math.max()

let arr = [1,33,4,22,99,7]

let max = Math.max.apply(Math,arr)

console.log(max); // 99

3. bind方法

=============================================================================

bind()方法不会调用函数。但是能改变函数内部this指向

3.1 写法


fun.bind(thisArg, arg1, arg2, …)

  • thisArg:指向谁

  • arg1:参数1

  • arg2:参数2

  • 返回由指定的this值和初始化参数改造的原函数拷贝,简单来说,就是将改造好产生的一个新函数返回给我们。

3.2 应用


  • 改变this指向

let o = {

name:‘Andy’

}

function fn() {

console.log(this); //o

}

let newFn = fn.bind(o)

newFn() //注意,此时才调用该函数

//1. 不会调用原来的函数,可以改变原来函数内部的this指向

//2. 返回的是原函数改变this之后产生的新函数

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

存中…(img-iugerWm3-1713501478255)]

最后

今天的文章可谓是积蓄了我这几年来的应聘和面试经历总结出来的经验,干货满满呀!如果你能够一直坚持看到这儿,那么首先我还是十分佩服你的毅力的。不过光是看完而不去付出行动,或者直接进入你的收藏夹里吃灰,那么我写这篇文章就没多大意义了。所以看完之后,还是多多行动起来吧!

可以非常负责地说,如果你能够坚持把我上面列举的内容都一个不拉地看完并且全部消化为自己的知识的话,那么你就至少已经达到了中级开发工程师以上的水平,进入大厂技术这块是基本没有什么问题的了。

资料领取方式:戳这里前往免费领取

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值