js 函数中this指向谁

JavaScript014

js 函数中this指向谁,第1张

谁调用函数,this就指向谁

1.this指向的,永远是对象

2.this指向谁, 不取决与this写在哪,而是取决于函数在哪调用

3.this指向的对象,我们成为函数的上下文context,也叫函数的调用者

1.通过函数名()直接调用:指向window

2.通过对象.函数名()调用:指向这个对象

3.通过数组下标.函数名()调用,指向这个数组

4.通过window内置函数( setInterval setTimeout 等)的回调里调用。指向window

5.函数作为构造函数,new关键字实例化之后调用,指向实例化对象

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)