js中的this指向 首先,js中的this指向是根据运行时确定的,而非定义时。...js中的this指向大致分为如下几种: 作为对象的方法调用 作为普通函数调用 构造调用 call、apply调用 作为对象的方法调用 var obj = { a: 1, getA: function...function(){ this.name = 'sven'; }; var obj = new MyClass(); alert ( obj.name ); // sven 一般情况下,构造调用时this指向...new后的对象,但是有种比较特殊,就是当构造函数return一个对象时(必须是对象,其余类型比如string请忽略)指向该对象。...指向: var obj1 = { name: 'sven', getName: function(){ return this.name; } }; var obj2 = { name
JS中this的指向 this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象。...console.log(this); }, t3: { // 测试对象中的对象 tt1: function() { console.log...(this); } }, t5: function(){ // 测试函数调用时箭头函数的this的指向,其指向了上一层对象的调用者 return {...,我们调用同一个方法,但是得到的this是不同的,要注意实际上this的最终指向的是那个调用它的对象 var s1 = { t1: function(){ console.log...由此,this指向了window 改变this指向 使用 apply、call、bind可以改变this的指向,可以参考 https://github.com/WindrunnerMax/EveryDay
this指向问题 this应该是第一个让人对JavaScript困惑的问题了,但是实际上它的原理非常简单:函数的this在运行时绑定。 什么叫运行时绑定?...就是函数的this和你写在哪里无关,而是和谁调用它有关。谁调用这个函数,this就指向谁。 你现在大概会在想:原来这么简单,我精通了!...先问自己:谁调用的它?你应该一下看不出来,这明明就是直接调的啊!可能有的基础比较扎实的人会说是window,那真是非常的恭喜你了,但你要注意的是以上代码在严格模式下是undefined。...正解:brother call / bind / apply 此为3种干预this指向的操作,限于篇幅不展开讲。...箭头函数 箭头函数可以让你省很多事,因为它的this一般来说都是符合你的直觉的:它的this就是定义时候的this。
函数中this指向对于一些开发者来说一直是一个比较头疼的问题,this在js中比较灵活,不同的情况指向不同,小shy总结出了函数调用的this指向的一些情况,供大家参考。 1....默认绑定 function fn() { console.log(this); } fn(); 结果:this指向window对象 函数在被调用的时候,this会默认指向全局对象window...obj对象,this.name 即 obj.name 调用对象的方法时会出现隐式绑定,fn是在obj对象里的,obj调用fn,this就会指向obj对象。...指向,所以fn函数调用this都指向了obj2对象,所以得出结果为小红。...(如果不太明白call()、apply() 和 bind(),可以看小shy之前的博客《js call()、apply()、bind()用法和区别》) 4.
全局上下文 非严格模式和严格模式中this都是指向顶层对象(浏览器中是window)。...指向为第一个参数的。...根据参数thisArg的描述,可以知道,call就是改变函数中的this指向为thisArg,并且执行这个函数,这也就使JS灵活很多。严格模式下,thisArg是原始值是值类型,也就是原始值。...非严格模式下,null和undefined,指向全局对象(浏览器中是window),其余值指向被new Object()包装的对象。 对象上的函数调用:绑定到那个对象。...这其实和 ES6 之前代码中的 self = this 机制一样。 DOM事件函数:一般指向绑定事件的DOM元素,但有些情况绑定到全局对象(比如IE6~IE8的attachEvent)。
this指向是js开发中必须掌握的知识,今天我们就用一道题目来看看你的基础。 ? 各位认为会输出什么呢?请大家先思考不要直接去运行看答案。 实际上会输出:5和2。...(1):第一行fn(),这个毫无疑问,this指向的是window,所以length自然输出5,大家不要看到fn()在obj对象里面调用,就把this认为指向了obj,这是非常错误的; this指向谁,...是在于函数执行时的环境对象,fn()在执行时,他的环境对象依然是window,这里的fn()大家可以理解为window.fn(),是这样进行执行的。...所以,这里大家可以理解为:arguments[0]()=arguments.fn(); this对象就是指向了arguments,length也自然是2了。...大家明白了吗,这道题对于this指向还是比较经典的题目,如果这道题可以独立做出来,证明this指向这块,你基本上是过关的。
// 对象里的方法写的是箭头函数,this始终访问全局 var name = "xiaoming"; var obj1...let getName11 = obj1.getName.bind(obj1); getName11(); // xiaoming // 对象的方法写的...function 声明,直接调用 this 指向对象本身,将调用的方法单独保存起来调用,this 指向全局,通过bind 改写 this 指向后,可以继续指向 对象本身 var
,第一,加深自己的理解,重新理一遍关于这方面的知识,第二,我尽可能的使用通俗简单的说辞进行解释 力求让更多的人明白这个东西,第三,this是js中的一个关键字,很有必要单独拿出来写一篇文章。...js中的this this js中的this总是指向一个对象,也就是一个obj,但是具体指向的是哪一个obj是根据具体的运行时函数的执行环境动态绑定的,而不是函数被声明的环境!...this的指向 如果不考虑常用的with和eval的情况下,具体到实际应用中,this的指向大致可以分为下面四类: 作为对象的方法调用 作为普通函数调用 构造器调用 Function.prototype.call...,也就是我们常见的普通函数使用的时候,此时的this其实指向的是当前的全局对象,也就是windows,因为在js中全局对象就是windows window.name = "globalName...JS中很多别的不好理解的概念差不多,用的多了就明白了为什么那么写,很多的时候我们看到一个错,就知道需要使用let that = this类似这样的代码块解决,究其原因是他很理解错误的原因吗?
对象的方法中如果对象的方法里面包含this,this的指向就是方法运行时所在的对象。该方法赋值给另一个对象,就会改变this的指向。但是,这条规则很不容易把握。请看下面的代码。...foreach方法的回调函数中的this,其实是指向window对象,因此取不到o.v的值。...a函数中的this关键字,如果指向全局对象,返回结果为123。...注意:如果是严格模式或者vue(vue默认严格模式)中,传入null则指向null,传入window则指向window如果call方法的参数是一个原始值,那么这个原始值会自动转成对应的包装对象,然后传入...myCall函数中this指向调用者,也就是执行myCall的函数,这里称之为a函数。将a函数的引用赋值给obj.fn,等同于a函数执行的时候,内部的this指向obj。这里就实现了this的绑定。
js中this到底指向什么? 一、前言 前段时间,公司让我改一个界面,我心想改个界面还不简单吗?结果呃,我低估了这颗炸弹的威力。 好吧是我太菜,总结一下,这个this的指向问题。...在js中,this的指向在定义函数的时候是确定不了的,只有在使用这个函数的时候才能确定this的指向。 一般来说在使用时,谁调用的这个函数,函数中的this就指向它。...对象中的函数,在运行时this指向了me这个对象。...在js中,this的指向在定义函数的时候是确定不了的,只有在使用这个函数的时候才能确定this的指向。 这样,我稍微能理解点了,简单的来说就是谁调用的这个函数,函数里面的this就指向谁。...如此,这段的解释就是,在window环境下启用这个定时器,将立刻执行me.showName这个函数。 由此来看,定时器启动的函数中的this都是指向与window。
1. this 的奥秘 很多时候, JS 中的 this 对于咱们的初学者很容易产生困惑不解。 this 的功能很强大,但需要一定付出才能慢慢理解它。...logInfo完全相同,但是此时的 this 指向 myCat,即使在函数调用中也是如此。...构造函数的作用就是去初始化这个对象。 可能你已经知道了,在这种类型的调用中,上下文指向新创建的实例。...构造函数中的 this 在构造函数调用中 this 指向新创建的对象 构造函数调用的上下文是新创建的对象。它利用构造函数的参数初始化新的对象,设定属性的初始值,添加事件处理函数等等。 ?...)中定义,因此 this 指向window对象。
首先先说下正常的 this 指向问题 什么是 this:自动引用正在调用当前方法的.前的对象。...this指向的三种情况 1. obj.fun() fun 中的 this->obj ,自动指向.前的对象 2. new Fun() Fun 中的 this->正在创建的新对象,new 改变了函数内部的...this 指向,导致 this 指向实例化 new 的对象 3. fun() 和匿名函数自调 this 默认->window,函数内部的 this,this 默认是指向 window 的 再说回调函数中的...自动指向了回调函数外层的 this 。...箭头函数中的 this: 函数体内的 this 对象,就是定义时所在的对象,而不是使用时所在的对象。
js中this的指向是在运行时会变动的 这句话严谨的说是有问题的。 this这个关键词,在java中的解释是引用当前类的实例变量。...,那么,这个函数的调用者就是此函数执行的作用域中的this 所以,归根结底,this是当前执行方法的调用者 你以为这样就结束了?...Too young too simple js中还有三个显式绑定this的方法,bind,apply,call当使用这些方法指定执行函数的this时,那this基本上就是指定的了 基本上?...上面的代码用babel编译之后 var _this = this; var sayThis = function () { console.log(_this); }; 复制代码 很容易理解箭头函数中this...的指向 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/100937.html原文链接:https://javaforall.cn
我喜欢在JS中更改函数执行上下文的指向,也称为 this 指向。...现在在`getFullName()` 方法中,`this`的值是全局对象(浏览器环境中的 `window` )。...如何使this指向所需的对象。...这种方法是在类中绑定this的最有效和最简洁的方法。 6. 总结 与对象分离的方法会产生 this 指向不正确问题。静态地绑定this,可以手动使用一个附加变量self来保存正确的上下文对象。...然而,更好的替代方法是使用箭头函数,其本质上是为了在词法上绑定this。 在类中,可以使用bind()方法手动绑定构造函数中的类方法。
javascript中的 this 的指向不太好控制,理解不好的话很容易错误 下面几个示例可以加深对this指向的理解 (1)内联事件 <a href="#" onclick="alert(this.tagName...( duang.hi, 1000); setInterval( duang.hi, 1000); 这两种情况都会弹出“我是 全局” 因为setTimeout和setInterval都会改变this<em>的</em><em>指向</em>为...属性值,而是弹出了button<em>的</em>name属性 说明这种方法会使this<em>指向</em>dom节点本身 如果想this<em>指向</em>duang对象,可以使用匿名函数解决 btn.onclick = function ()...){ duang.hi();}, 1000); setInterval( function (){ duang.hi();}, 1000); 可以看到,这种直接调用和通过匿名函数间接调用 对this<em>的</em><em>指向</em>影响很大...函数 这时<em>的</em>点击结果为 "I'm 全局",说明this指向了window对象 注意,使用call和apply调用方法时,this的指向会被改为window
问题:在外部单独使用类实例对象的方法,this没有指向该类实例对象 代码如下 class CQH { hello() { let name = this.name();...this.name(); ^ TypeError: Cannot read property 'name' of undefined 原因:虽然类默认的方法指向类的实例...,但是如果在外部单独使用该方法,this会指向该方法运行时所在的环境,不再指向对象 解决办法 1....显示指定bind方法指定this 可以在构造方法中绑定this class CQH { constructor() { this.hello = this.hello.bind(...总是指向定义时所在的对象,是在构造函数执行的时候,箭头函数所在的运行环境,肯定是实例对象,所以this会总是指向实例对象。
开始从js的this对象说起,this对象就是函数执行的环境对象。...结果分析说明 GetName函数是在全局环境中定义,所以直接调用函数this就指向了全局环境,所以输出Jack。...(注意函数不加后面()的时候,那时候就不是调用,那只是一个包含函数指针的变量) 由于函数执行环境变成了obj对象,所以this只想就指向了obj,所以自然就输出了“Tom”。...函数扩展this对象 es5提供了三个函数非继承的方法,可以直接改变this的指向,但是在书中说是扩充函数作用域,但是我认为改变this指向更贴切一点。...三个方法分别为:apply,call,bing,用法都比较简单,作用也都是改变函数的this指向,下面我就用代码来简单说明一下。
js中this指向问题及call,apply,bind的区别# 1 this指向# 1.1 what is 'this'?...# 在 ECMAScript 5 中,函数内部存在两个特殊的对象:arguments(一个类数组对象,包含调用函数时传入的所有参数) 和 this(本文将要讲的)。...1.2 标准函数与箭头函数的this指向# this在标准函数与箭头函数中的时会有两种不同类型的指向行为。...1.2.1 标准函数的this指向# 在标准函数中,this 指向的是把函数当成方法调用的上下文对象。也就是说在哪里调用的这个函数,那这个this只会指向它外面最靠近它的对象。...# 当箭头函数时,this指向的是定义箭头函数的上下文。
this this指向只和调用函数的对象有关; 多层嵌套的对象,内部方法的this指向离被调用函数最近的对象(window也是对象,其内部对象调用方法的this指向内部对象, 而非window); function...原型链中的方法的this仍然指向调用它的对象; var o = { f : function(){ return this.a + this.b; } }; var p = Object.create...类的构造函数中,this 是一个常规对象,与构造函数的this一样; 类中所有非静态的方法都会被添加到 this 的原型中; (静态方法不是 this 的属性,它们只是类自身的属性。)...this 当this传入内联处理函数时,它的this指向监听器所在的DOM元素; 当this没有传入内联处理函数时,其this指向等同于 函数直接调用的情况,即在非严格模式指向全局对象window, 在严格模式指向...this setTimeout 和 setInterval中的普通函数this指向全局对象window; (如果传入的函数已绑定this或者是箭头函数,则不适用这条,需要继续往下看) function
本文继续讨论 this 指向 问题,今天讨论: 函数中的this 0 1 箭头函数 箭头函数忽略任何形式的this指向改变....当在严格模式下,test打印还是为window, test2 则打印undefined 箭头函数中的this ,不是谁调用就指向谁 示例2: obj.test=()=>{ console.log...); } t2(); } t1(); } obj.test(); 结果为:window 总结:箭头函数 this 作用域, 指向外层非箭头函数作用域的...总结: call、apply、bind 三个方法都可以改变函数中this 的指向 call、apply :立即执行 bind 返回一个新函数 var obj={ name:'sunshine',...{name:'Double yong'} 改变this obj.sayHi.call(obj2); obj.sayHi.apply(obj2); 上面的代码,将立即调用函数,且打印obj2.name中的
领取专属 10元无门槛券
手把手带您无忧上云