1、call apply和bind的作用和区别
作用:
都可以改变函数内部的this指向。
区别点:
1、call 和 apply 会调用函数,并且改变函数内部this指向。
2、call 和 apply 传递的参数不一样,call 传递参数arg1,arg2...形式 apply 必须数组形式[arg]
3、bind不会调用函数,可以改变函数内部的this指向。
解析:
call方法
call()方法调用一个对象。简单理解为调用函数的方式,但是它可以改变函数的this指向。
写法:fun.call(thisArg, arg1, arg3, …) // thisArg为想要指向的对象,arg1,arg3为参数
call 的主要作用也可以实现继承
function Person(uname, age) {
this.uname = uname;
this.age = age;
}
function Son(uname, age) {
Person.call(this, uname, age);
}
var son = new Son("zhang", 12);
console.log(son);
apply方法
apply()方法调用一个函数。简单理解为调用函数的方式,但是它可以改变函数的this指向。
写法:fun.apply(thisArg, [argsArray])
1、thisArg:在fun函数运行时指定的this值
2、argsArray:传递的值,必须包含在数组里面
3、返回值就是函数的返回值,因为他就是调用函数
apply的主要应用,比如可以利用apply可以求得数组中最大值
const arr = [1, 22, 3, 44, 5, 66, 7, 88, 9];
const max = Math.max.apply(Math, arr);
console.log(max);
bind方法
bind()方法不会调用函数,但是能改变函数内部this指向.
写法:
fun.bind(thisArg, arg1, arg2, ...)
1、thisArg:在fun函数运行时指定的this值。
2、arg1,arg2:传递的其他参数。
3、返回由指定的this值和初始化参数改造的原函数拷贝。
var o = {
name: "lisa"
};
function fn() {
console.log(this);
}
var f = fn.bind(o);
f();
如果有的函数我们不需要立即调用,但是又需要改变这个函数的this指向,此时用bind再合适不过了。
const btns = document.querySelectorAll("button");
for (let i = 0; i < btns.length; i++) {
btns[i].onclick = function() {
this.disabled = true;
setTimeout(
function() {
this.disabled = false;
}.bind(this),
2000
);
};
}
扩展:
主要应用场景:
1、call 经常做继承。
2、apply 经常跟数组有关系,比如借助于数学对象实现数组最大值最小值。
3、bind 不调用函数,但是还想改变this指向,比如改变定时器内部的this指向。
2、this指向(普通函数,箭头函数)
普通函数中的this:
1、谁调用了函数或者方法,那么这个函数或者对象中的this就指向谁。
let getThis = function () {
console.log(this);
}
let obj={
name:"Jack",
getThis:function(){
console.log(this);
}
}
//getThis()方法是由window在全局作用域中调用的,所以this指向调用该方法的对象,即window
getThis();//window
//此处的getThis()方法是obj这个对象调用的,所以this指向obj
obj.getThis();//obj
1、匿名函数中的this:匿名函数的执行具有全局性,则匿名函数中的this指向是window,而不是调用该匿名函数的对象;
let obj = {
getThis: function () {
return function () {
console.log(this);
}
}
}
obj.getThis()(); //window
上面代码中,getThi()方法是由obj调用,但是obj.getThis()返回的是一个匿名函数,而匿名函数中的this指向window,所以打印出window。 如果想在上述代码中使this指向调用该方法的对象,可以提前把this传值给另外一个变量(_this或者that):
let obj = {
getThis: function () {
//提前保存this指向
let _this=this
return function () {
console.log(_this);
}
}
}
obj.getThis()(); //obj
3、箭头函数能否当构造函数
箭头函数表达式的语法比函数表达式更简洁,并且没有自己的this,arguments,super或new.target。箭头函数表达式更适用于那些本来需要匿名函数的地方,并且它不能用作构造函数。
4、继承的优点和缺点?
继承的好处:
1、提高代码的复用性
2、提高代码的维护性
3、让类与类之间产生了关系,是多态的前提。
继承的弊端:
1、类的耦合性增强了,但是开发的原则,高内聚低耦合。
5、new会发生什么?
1、创建空对象
var obj = {}
2、设置新对象的constructor属性为构造函数的名称,设置新对象的proto属性指向构造函数的prototype对象。
obj.__proto__ = classA.prototype
3、使用新对象调用函数,函数的this被指向新实例对象。
classA.call(obj)
4、返回this指针。当存在显示返回时,返回return后面的内容,新建空对象作废。
function test() {
this.name = "test";
}
test.prototype = {
a:{},
b:{}
}
var c = new test();
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://blog.csdn.net/weixin_47450807/article/details/124526619
内容来源于网络,如有侵权,请联系作者删除!