js中的this如何使用

JavaScript011

js中的this如何使用,第1张

在一般函数方法中使用 this 指代全局对象

2.作为对象方法调用,this 指代上级对象

3.作为构造函数调用,this 指代new 出的对象

4.apply 调用 ,apply方法作用是改变函数的调用对象,此方法的第一个参数为改变后调用这个函数的对象,this指代第一个参数

1.arguments,伪数组,包含函数中所有的参数

2.函数如果不给任何条件,那么this默认指向window

3.如果要指定this就通过call来传this

fn.call(1)

如果传的this不是对象,那么js会自动帮忙封装为对象 

这时的this是1对象

如何声明的时候不转化为对象呢

function fn(){

'use strict'

console.log(this)

}

fn.call(1),this就是1

f.call(1,2,3,4)

此时对象1就是this,234就是arguments

4.this是隐藏参数,arguments是显示参数

5.let person={

name:'frank',

sayHi(){

console.log("你好,我叫"+person.name)}

}

我们可以用直接保存了对象地址的变量获取name

这种方法称为引用:变量保存了对象的地址

6.js在每一个函数都加上一个this,用this获取目前还不知道名字的对象

7.call指定this

fn.call(this,参数1,参数2)