JavaScript中apply()和call()的区别和应用

function Animal(name) {

this.name = name

this.showName = function () {

console.log(this.name)

}

}

function Cat(name) {

// Cat调用Animal方法,同 Animal.call(this, name)

Animal.apply(this, [name])

}

var cat = new Cat(‘小猫’)

cat.showName()

输出:

小猫

多重继承

function Func1() {

this.sub = function (a, b) {

console.log(a - b)

}

}

function Func2() {

this.add = function (a, b) {

console.log(a + b)

}

}

function Func3() {

// Func3调用Func1方法,同 Func1.call(this)

Func1.apply(this)

// Func3调用Func2方法,同 Func2.call(this)

Func2.apply(this)

}

var func = new Func3()

func.sub(1, 2)

func.add(1, 2)

输出:

-1

3

apply妙用1

var numbers = [5, 6, 1, 3, 7];

var max = Math.max.apply(null, numbers)

console.log(max)

var min = Math.min.apply(null, numbers)

console.log(min)

输出:

7

1

Math.max()方法,只能传递参数列表Math.max(param1, param2…),不支持Math.max([ 《大厂前端面试题解析+Web核心总结学习笔记+企业项目实战源码+最新高清讲解视频》无偿开源 徽信搜索公众号【编程进阶路】 param1, param2]) 。借助apply,我们可以将一个数组参数转换为一个参数列表([param1, param2…] 转换为 (param1,param2…)

apply妙用2

var arr1 = new Array(“1”,“2”,“3”)

var arr2 = new Array(“4”,“5”,“6”)

// push返回数组长度

Array.prototype.push.apply(arr1, arr2) // 等价于arr1.push(“4”,“5”,“6”)

console.log(arr1)

输出:
6   
[“1”, “2”, “3”, “4”, “5”, “6”]

与君共勉:再牛逼的梦想,也抵不住傻逼般的坚持!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值