老生常谈 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