老生常谈 js中this的指向

作者:jingxian 时间:2024-04-23 09:29:31 

在js中this的指向对于新手来说一定是个难题,但是如果你真正理解了的话,也就没什么问题啦,下面就来讲讲this吧。

JS中,this的值取决于调用的模式(调用对象),而JS中共有4种调用模式:

1.函数调用模式

当一个函数不是一个对象的属性时,当作函数俩调用,这时函数内的this指向全局对象(大对数情况下是window)


window.value=1;
function getValue(){
console.log(this.value);
}
getValue();//输出1,此时的this指向window

2.方法调用模式

当一个函数是一个对象的属性时,我们称它为该对象的一个方法,当一个方法被调用时,this指向该对象


var Obj={
 value:2,
 getValue:function(){
      console.log(this.value);//输出2,this指向Obj
 }  
}

!!!该模式中,this到对象的绑定发生在方法被调用时

3.构造器调用模式

使用new调用的函数称为构造器函数,此时的this指向该构造器函数实例出来的对象


function main(val){
 this.value=val;
}
main.prototype.getValue=function(){
 console.log(this.value);
}

var fun=new main(3);
fun.getValue();
fun.value;//输出3,this指向main的实例对象fun

4.apply/call调用模式以及bind

apply、call、bind方法可以让我们设定调用者中的this指向谁


function showValue(){
 console.log(this.value);
}
var obj={
 value:4
}
showValue.call(obj)//输出4,this指向了obj对象

ECMA5中新增了bind方法,具体用法可以google一下,这里是演示this绑定的用法


function showValue(){
 console.log(this.value);
}
var obj={
 value:4
}
var showValue2=showValue.bind(obj);
showValue2()//输出4,this指向了obj对象

bind有很多种用法,可以自己去查阅一下哦

标签:js,this,指向
0
投稿

猜你喜欢

  • 6行的js上下滑动广告效果

    2008-11-27 12:26:00
  • python实现控制COM口的示例

    2023-01-01 03:57:05
  • Python编程基础之构造方法和析构方法详解

    2022-02-26 02:38:03
  • MySQL按照汉字的拼音排序简单实例

    2024-01-22 00:32:41
  • python 实现提取log文件中的关键句子,并进行统计分析

    2022-04-19 06:24:09
  • 巧妙的Sql函数日期处理方法

    2009-05-25 17:59:00
  • Pandas 合并多个Dataframe(merge,concat)的方法

    2021-07-14 07:26:58
  • python笔记_将循环内容在一行输出的方法

    2022-08-11 20:27:09
  • Python回文字符串及回文数字判定功能示例

    2022-05-09 21:59:30
  • Python实现识别图片内容的方法分析

    2022-01-04 21:10:51
  • python数据分析之线性回归选择基金

    2022-03-09 08:13:59
  • 用gpu训练好的神经网络,用tensorflow-cpu跑出错的原因及解决方案

    2021-02-11 08:06:31
  • 改善IE6中a与a:hover的背景支持

    2009-11-27 18:50:00
  • AJAX缓存的问题解决办法

    2009-04-26 14:47:00
  • MySQL 外键约束和表关系相关总结

    2024-01-17 00:09:26
  • layer弹出子iframe层父子页面传值的实现方法

    2024-04-19 09:56:10
  • 学习ASP.NET八天入门:第六天

    2007-08-07 13:48:00
  • Python使用pandas处理CSV文件的实例讲解

    2021-01-31 18:23:37
  • Golang 实现Redis 协议解析器的解决方案

    2024-02-19 20:09:36
  • Linux下python与C++使用dlib实现人脸检测

    2023-06-13 16:13:20
  • asp之家 网络编程 m.aspxhome.com