首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS中this的指向

JS中this的指向 this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象。...实例 定义函数与对象并调用,注意只有调用函数才会使this指向调用者,但箭头函数除外。...}, t5: function(){ // 测试函数调用时箭头函数的this的指向,其指向了上一层对象的调用者 return { tt1: () => {...我们调用同一个方法,但是得到的this是不同的,要注意实际上this的最终指向的是那个调用它的对象 var s1 = { t1: function(){ console.log(...,由此,this指向了window 改变this指向 使用 apply、call、bind可以改变this的指向,可以参考 https://github.com/WindrunnerMax/EveryDay

1.9K20

js中this到底指向什么?

js中this到底指向什么? 一、前言 前段时间,公司让我改一个界面,我心想改个界面还不简单吗?结果呃,我低估了这颗炸弹的威力。 好吧是我太菜,总结一下,这个this的指向问题。...在js中,this的指向在定义函数的时候是确定不了的,只有在使用这个函数的时候才能确定this的指向。 一般来说在使用时,谁调用的这个函数,函数中的this就指向它。...对象中的函数,在运行时this指向了me这个对象。...在js中,this的指向在定义函数的时候是确定不了的,只有在使用这个函数的时候才能确定this的指向。 这样,我稍微能理解点了,简单的来说就是谁调用的这个函数,函数里面的this就指向谁。...所以这时候,this的真正指向就是返回的那个对象

91410

JS数据类型、数组、this指向复习

Symbol:ES6新增的数据类型,用Symbole()函数来定义,代表定义的变量值的唯一性 引用数据类型(复杂数据类型) Object,Array,Function,RegExp,String 对象类型可以添加属性...检测对象是否是对象自身的属性:hasOwnProperty for(var key in obj) { if(obj.hasOwnProperty(key)) { console.log(obj...replace(要查找的字符串或匹配的正则,要替换的内容) 替换 indexOf() 查找,有返回下标,没有返回-1 includes() 同数组用法 有返回true,没有返回false 四、数学对象...Math.min.apply(Math,arr) Math.min.call(Math,…arr) Math.max.call(Math,…arr) Math.min() 取小值 五、this指向.../ let _this=this; setTimeout(()=> { console.log(this===btn) },0) } 总结:this通常是谁调用,this指向

1.4K10

js中关于this指向的训练题

this指向js开发中必须掌握的知识,今天我们就用一道题目来看看你的基础。 ? 各位认为会输出什么呢?请大家先思考不要直接去运行看答案。 实际上会输出:5和2。...首先我们找到method,里面的两段代码实际都是执行了fn函数,只是this对象不同。...(1):第一行fn(),这个毫无疑问,this指向的是window,所以length自然输出5,大家不要看到fn()在obj对象里面调用,就把this认为指向了obj,这是非常错误的; this指向谁,...是在于函数执行时的环境对象,fn()在执行时,他的环境对象依然是window,这里的fn()大家可以理解为window.fn(),是这样进行执行的。...所以,这里大家可以理解为:arguments[0]()=arguments.fn(); this对象就是指向了arguments,length也自然是2了。

79710

关于JS中this指向问题的探究

写在前面 本篇文章的所有例子来源都是《JS设计模式与开发实践》这本书,写这篇文章之前也去查阅了很多关于this指向问题的探讨,包括但不仅仅有像阮一峰老师,还有很多的博主的帖子,还是决定写这篇文章有以下几个原因...js中的this this js中的this总是指向一个对象,也就是一个obj,但是具体指向的是哪一个obj是根据具体的运行时函数的执行环境动态绑定的,而不是函数被声明的环境!...this的指向 如果不考虑常用的with和eval的情况下,具体到实际应用中,this的指向大致可以分为下面四类: 作为对象的方法调用 作为普通函数调用 构造器调用 Function.prototype.call...,也就是我们常见的普通函数使用的时候,此时的this其实指向的是当前的全局对象,也就是windows,因为在js中全局对象就是windows window.name = "globalName...,那么他的返回值就会被这个新的对象给替换,因为this指向的是一个对象

1.4K31

面试官问:JS的this指向

1.面试官问:能否模拟实现JS的new操作符 2.面试官问:能否模拟实现JS的bind方法 3.面试官问:能否模拟实现JS的call和apply方法 4.面试官问:JS的this指向 5.面试官问:JS...的继承 面试官出很多考题,基本都会变着方式来考察this指向,看候选人对JS基础知识是否扎实。...之前写过一篇文章:面试官问:能否模拟实现JS的call和apply方法就是利用对象上的函数this指向这个对象,来模拟实现call和apply的。感兴趣的读者思考如何实现,再去看看笔者的实现。...之前也写了一篇文章面试官问:能否模拟实现JS的new操作符,是使用apply来把this指向到生成的新生成的对象上。感兴趣的读者思考如何实现,再去看看笔者的实现。...非严格模式下,null和undefined,指向全局对象(浏览器中是window),其余值指向被new Object()包装的对象对象上的函数调用:绑定到那个对象

74320

PHP关键字this指向当前对象指针

PHP关键字this是指向当前对象的指针。我们将和大家一起结合一个范例来细细研究一下PHP关键字this的相关用法和具体功能体现。 <?...打印用户名成员函数 function printName() { print($this->name); //又使用了PHP关键字this指针 } } //实例化对象...nameObject = new UserName ("heiyeluren"); //执行打印 $nameObject->printName(); //输出: heiyeluren //第二次实例化对象...> 我 们看,上面的类分别在11行和20行使用了this指针,那么当时this是指向谁呢?...其实this是在实例化的时候来确定指向谁,比如第一次实例化对象 的时候(25行),那么当时this就是指向nameObject对象,那么执行18行的打印的时候就把print( this-><name )

1.9K10

一文读懂Js中的this指向

由于对象的属性可以赋给另一个对象,所以属性所在的当前对象是可变的,即this的指向是可变的。...对象的方法中如果对象的方法里面包含this,this的指向就是方法运行时所在的对象。该方法赋值给另一个对象,就会改变this的指向。但是,这条规则很不容易把握。请看下面的代码。...,这时this只是指向当前一层的对象,而不会继承更上面的层。...(浏览器为window对象);call方法可以改变this的指向,指定this指向对象obj,然后在对象obj的作用域中运行函数f。...如果使用call方法将this关键字指向obj对象,返回结果为456。可以看到,如果call方法没有参数,或者参数为null或undefined,则等同于指向全局对象

88100

JS 中 this 在各个场景下的指向

函数可以使用.bind()方法与对象绑定,就可以解决 this 指向的问题。...这个对象的初始化由这个类中一个特殊的方法constructor来处理。其中,this指向新创建的对象。 构造函数创建了一个新的空的对象,它从构造函数的原型继承了属性。...构造函数的作用就是去初始化这个对象。 可能你已经知道了,在这种类型的调用中,上下文指向新创建的实例。...构造函数中的 this 在构造函数调用中 this 指向新创建的对象 构造函数调用的上下文是新创建的对象。它利用构造函数的参数初始化新的对象,设定属性的初始值,添加事件处理函数等等。 ?...JS中的函数是第一类对象,这意味着函数就是对象对象的类型为Function。从函数对象的方法列表中,.call()和.apply()用于调用具有可配置上下文的函数。

4.4K10

This指向与改变This指向

This指向与改变This指向 This 的指向 在 ES5 中,其实 this 的指向,始终坚持一个原理:this 永远指向最后调用它的那个对象。...所以 this 指向的也就是 window。 this 的指向并不是在创建的时候就可以确定的,在 es5 中,永远是this 永远指向最后调用它的那个对象。...我们将 this(指向变量 a) 赋值给一个变量 _this,这样,在 func2 中我们使用 _this 就是指向对象 a 了。...result : obj; } 创建一个空对象 obj; 将新创建的空对象的隐式原型指向其构造函数的显示原型。...使用 call 改变 this 的指向 如果无返回值或者返回一个非对象值,则将 obj 返回作为新对象;如果返回值是一个新对象的话那么直接直接返回该对象

1.2K20

js中扩充函数作用域(改变this指向)

开始从js的this对象说起,this对象就是函数执行的环境对象。...结果分析说明 GetName函数是在全局环境中定义,所以直接调用函数this就指向了全局环境,所以输出Jack。...之后我们定义了一个obj对象,然后也定义了一个属性GetNames,并赋值了GetName这个函数的指针。...(注意函数不加后面()的时候,那时候就不是调用,那只是一个包含函数指针的变量) 由于函数执行环境变成了obj对象,所以this只想就指向了obj,所以自然就输出了“Tom”。...函数扩展this对象 es5提供了三个函数非继承的方法,可以直接改变this的指向,但是在书中说是扩充函数作用域,但是我认为改变this指向更贴切一点。

2.6K11
领券