JS中的this指向是怎样的,this怎么使用
Admin 2022-06-01 群英技术资讯 308 次浏览
JS中的this指向一直是个让初学者头疼的问题。今天,我们就一起来瞅瞅this倒地是咋回事,详细说说this指向原则,从此不再为了this指向操碎了心。
首先我们都知道this是Javascript语言的一个关键字。
它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用。随着函数使用场合的不同,this的值会发生变化。但是有一个总的原则,那就是this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它所在函数的对象。 那么接下来我们一步步探索下这个问题。
function a() { var user = "清蒸胖头鱼"; console.log(this.name); //undefined console.log(this); //Window } a(); window.a();//两种结果相同
如我们上文所说的this的最终指向的是那个调用它所在函数的对象,这里a其实是由window对象点出来的。
var obj = { name: '清蒸胖头鱼', f1: function () { console.log(this.name);//清蒸胖头鱼 } }; obj.f1();
再次强调一点this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁;这个例子this所在的f1函数是由obj对象调用的,所以这里的this指向obj对象。
如果要彻底的搞懂this必须看接下来的几个例子
var obj = { a: 5, b: { a: 10, fn: function () { console.log(this.a); //10 } } }; obj.b.fn();
不是说this的最终指向的是那个调用它所在函数的对象吗?这里为什么不指向obj对象呢?
这里需要补充三点:
看到这相信大家基本掌握了this指向的原则了吧,再碎碎念一遍:this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它所在函数的对象。
构造函数(new 关键字)情况
function Student() { this.name = '清蒸胖头鱼'; } var s1 = new Student(); console.log(s1.name);// 清蒸胖头鱼
这里之所以对象s1可以点出函数Student里面的name 是因为new关键字可以改变this的指向,将这个this指向对象s1.
// new 关键字执行的过程 1. 在函数体内创建一个空的对象. 2. 让当前this指向这个空的对象. 3. 通过this给当前空的对象添加键值对. 4. 返回已经添加好所有键值对的对象给外面的变量.
定时器里的this指向情况
var num = 0; function Obj() { this.num = 1; this.getNum1 = function () { console.log(this.num); }; this.getNum2 = function () { setInterval(function () { console.log(this.num); }, 1000); }; } var o = new Obj(); o.getNum1();//1 (o.num) o.getNum2();//0 (window.num)
o.getNum2()
值之所以为0,也就是这里的this
指向window
,再拿出我们的this指向原则解释:this
的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this
到底指向谁,实际上this
的最终指向的是那个调用它所在函数的对象。
解: this.num
所在的函数为定时器setInterval
内的function () { console.log(this.num);}
,根据this指向原则当该函数被执行,this指向它的上一级对象。setInterval
,又因setInterval
是window
点出了的,所以this
指向window
。
call
、apply
、bind
改变指向情况
var num = 0; function Obj() { this.num = 1; this.getNum1 = function () { console.log(this.num); }; this.getNum2 = function () { setInterval(function () { console.log(this.num); }.bind(this), 1000);//利用bind将this绑定到这个函数上 }; } var o = new Obj(); o.getNum1();//1 (o.num) o.getNum2();//1 (o.num)
解释:
bind()方法是Function.prototype上的一个方法,当被绑定函数调用时,bind方法会创建一个新函数,并将第一个参数作为新函数的运行时的this。
根据原则:
没使用bind
方法前:被调用时:this.num
指向的是调用它所在函数的对象,也就是window.setTimeout
对象。 使用bind
方法后:被调用时:将原来的this
重新指向到→调用getSum2
函数(就是新this
所在的函数)的对象。这里构造函数,通过new
调用,所以指向o对象。
bind
方法在该情况比较常用,当然如果使用call
或apply
方法来代替也行,得到的结果也是正确的,但是call
和apply
方法会在调用后马上执行,那样就没了延时的效果,定时器也就没有意义了。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
前台----> 后台后台要接受前台的数据,只能通过http 但是前台接受后台的数据有 from ajax jsonpnodejs给我们提供了模块url模块,可以专门解析url地址让我们在走一遍流程案例:consthttp=require("http");//引入http模块,创建服务器constur
这篇文章主要介绍了JS 9个Promise面试题,对异步Promise感兴趣的同学,可以参考下
目录引言设计原则1. 明确不同角色的职责2. 发挥代码的威力,而不是限制3. 各个层面的可扩展性4. 专注而不是发散Sunmao 的工作原理响应最新的状态组件间交互布局与样式类型安全在组件间复用代码可扩展的可视化编辑器保持开放引言尽管现在越来越多的人开始对低代码开发感兴趣,但已有低代码方案的一些局限性仍然让大家有所保留
对于JS的运算符和操作符大家应该都比较熟悉,例如+、-、++、=、!等等这些都是比较常见的,但是JavaScript运算符和操作符有很多,有很比较少见的运算符和操作符,很多人可能都了解,因此这篇文章就给大家介绍一下这一下比较少见的运算符和操作符,感兴趣的朋友可以了解看看。
JavaScript中如何在一个循环中等待示例代码详解 下面是如何使用for..of 循环来迭代一个数组并在循环内等待: const fun = (prop) => { return new Promise(resolve => { setTimeout(() => resolve(`done ${prop}`), 1000); }) } const go = async () => { const list = [1, 2, 3] for (const prop of list) { console.log(prop) co ...
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008