首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在不使用箭头函数的情况下获取函数内的主类对象

,可以通过以下步骤实现:

  1. 首先,需要在函数内部创建一个指向主类对象的变量。这可以通过在函数内部使用this关键字来实现。this关键字在函数内部指向调用该函数的对象。
  2. 接下来,可以使用bind()方法将函数绑定到主类对象上。bind()方法会创建一个新的函数,该函数的this值被设置为传入的参数。在这种情况下,将主类对象作为参数传递给bind()方法,以确保函数内部的this指向主类对象。
  3. 最后,可以调用绑定后的函数来获取主类对象。这将返回一个函数,可以像调用普通函数一样调用它,以获取主类对象。

以下是一个示例代码:

代码语言:javascript
复制
function MyClass() {
  this.name = "MyClass";
  
  this.getMainObject = function() {
    var self = this; // 创建指向主类对象的变量
    var getMainObjectFunc = function() {
      return self; // 返回主类对象
    }.bind(this); // 将函数绑定到主类对象上
    return getMainObjectFunc(); // 调用绑定后的函数获取主类对象
  };
}

var myObj = new MyClass();
var mainObj = myObj.getMainObject();
console.log(mainObj); // 输出主类对象

这样,通过以上步骤,可以在不使用箭头函数的情况下获取函数内的主类对象。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

_类内成员函数可以访问本类对象的私有成员

类内成员函数可以访问本类对象的私有成员 sList是一个类 私有成员是head,有一个成员函数的形参是本类对象(的引用,引不引用不影响结论和原因) ==为什么呢!...对象b是sList类的,而这个intersection函数是sList的成员函数 head虽然是sList类的对象的私有成员,但是是在sList类内访问的 ==就是 在类内访问了本类(的实例化对象)的私有成员...因为这是在类内访问的,又不是在类外== 这说明了,类的成员的访问权限,是对于==类==而言的,决定在==类==外是否可被访问 而非对于对象来说的(因为对象不同但是都是属于同一种类,类的实例化对象的成员,...本来就是类的成员,只是抽象和实例化的问题 这非常合理地体现了 类 的封装性 这个就是不行的,在类外访问了 这一点是非常好用的,可以利用这一点 ==用成员函数肆无忌惮地访问对象的私有成员!...==只要声明函数是类的成员函数,将外部同类对象设为形参(或加个引用)就可以了!! 不必再为如何访问到同类外部对象的私有成员而苦思了!

86330
  • 分享一个关于this对象的编程小技巧,如何使用箭头函数避免this对象混淆?

    为什么使用箭头可以呢? 四 因为在箭头函数中,this对象与封闭词法环境中的this保持一致。换一句话,箭头函数中的this,是定义与执行它的函数中this对象。...或者我们可以理解为,箭头函数是没有this对象的。箭头函数中的this,取决于它身处何处。 那么,回顾一下,this是什么?...考虑一种特殊的情况,那么在全局作用作用域下,this指代谁呢? 在全局作用域下this指代全局对象 如果函数是全局函数,是在全局使用域中调用的,那么this等于全局对象。...apply与call的使用方法是类型的,也是在第一个参数的地方传递this对象;不同处在于bind只绑定不执行,而后两者是马上执行的。...但在大多数情况下,我们使用不捆绑this的箭头函数,来避免this对象的混淆问题,是最简单省事的方法。 11月7日

    1.2K41

    【Kotlin】:: 双冒号操作符详解 ( 获取类的引用 | 获取对象类型的引用 | 获取函数的引用 | 获取属性的引用 | Java 中的 Class 与 Kotlin 中的 KClass )

    文章目录 一、:: 双冒号操作符 1、获取类的引用 引用类型 KClass 说明 2、获取对象类型的引用 3、获取函数的引用 4、获取属性的引用 二、 java.lang.Class 与 kotlin.reflect.KClass...一、:: 双冒号操作符 ---- 在 Kotlin 中 , :: 双冒号操作符 的作用是 获取 类 , 对象 , 函数 , 属性 的 类型对象 引用 ; 获取的这些引用 , 并不常用 , 都是在 Kotlin...1、获取类的引用 在 Kotlin 中 , 使用 :: 双冒号操作符 获取 类的类型对象引用 代码格式为 : Java或Kotlin类名::class 获取的 Kotlin 类 的 类型对象 的类型...} 2、获取对象类型的引用 在 Kotlin 中 , 使用 :: 双冒号操作符 获取 对象类型的引用 代码格式为 : Java或Kotlin实例对象::class 获取的 对象类型的引用 的类型 为 KClass...相对的是 Java 中的 Class 类 , 是 Java 中的 类的 引用类型 ; 在 Java 语言中 , 需要通过 类名.class 获取 Class 实例对象 ; 在 Kotlin 语言中 ,

    4.8K11

    从零开始学C++之对象的使用(一):static 成员变量、static 成员函数、类对象的大小

    非static数据成员存在于类类型的每个对象中,static数据成员独立该类的任意对象存在,它是与类关联的对象,不与类对象关联。...(1)、static成员的定义 static成员需要在类定义体外进行初始化与定义 (2)、特殊的整型static const成员 整型static const成员可以在类定义体中初始化,...:     const int a;   //只能在构造函数初始化列表中初始化     static int b;    //在类的实现文件中定义并初始化     const static int c;...二、static 成员函数 static成员函数没有隐含的this指针 非静态成员函数可以访问静态成员 静态成员函数不可以访问非静态成员(实际上是直接访问是不可以的,间接地访问是可以的,比如通过类指针或类引用...endl;     return 0; } 三、类/对象大小计算 类大小计算遵循前面学过的结构体对齐原则(参照这里) 类的大小与数据成员有关与成员函数无关(空类大小为1个字节) 类的大小与静态数据成员无关

    1.2K00

    【C++】继承 ⑥ ( 继承中的构造函数和析构函数 | 类型兼容性原则 | 父类指针 指向 子类对象 | 使用 子类对象 为 父类对象 进行初始化 )

    地方 , 都可以使用 " 公有继承 " 的 派生类 ( 子类 ) 对象 替代 , 该 派生类 ( 子类 ) 得到了 除 构造函数 和 析构函数 之外的 所有 成员变量 和 成员方法 ; 功能完整性 :..." 公有继承 " 的 派生类 ( 子类 ) 本质上 具有 基类 ( 父类 ) 的 完整功能 , 使用 基类 可以解决的问题 , 使用 公有继承派生类 都能解决 ; 特别注意 : " 保护继承 " 和..." 私有继承 " 的 派生类 , 是 不具有 基类 的 完整功能的 , 因为 最终继承 后的派生类 , 无法在 类外部调用 父类的 公有成员 和 保护成员 ; 2、类型兼容性原则应用场景 " 类型兼容性原则..." 应用场景 : 直接使用 : 使用 子类对象 作为 父类对象 使用 ; 赋值 : 将 子类对象 赋值给 父类对象 ; 初始化 : 使用 子类对象 为 父类对象 初始化 ; 指针 : 父类指针 指向...子类对象 , 父类指针 值为 子类对象 在 堆内存 的地址 , 也就是 将 子类对象 地址 赋值给 父类类型指针 ; 引用 : 父类引用 引用 子类对象 , 将 子类对象 赋值给 父类类型的引用 ; 二

    30920

    React useEffect中使用事件监听在回调函数中state不更新的问题

    很多React开发者都遇到过useEffect中使用事件监听在回调函数中获取到旧的state值的问题,也都知道如何去解决。...对象类似于按钮btn refApp函数类似React App纯函数组件每次state变化,React 函数会重新执行,所以我们可以进行如下模拟操作图片这个示例的运行过程就比较好理解,第一次执行App函数...,初始化数据,Obj可以获取到函数内的a变量,因此,变量a所分配的内存不会释放,再运行App函数,Obj获取到的变量a始终是第一次初始化时的a在内存中指向的值。...在React函数中也是一样的情况,某一个对象的监听事件的回调函数,这个对象相当于全局作用域变量(或者与函数同一层作用域链),在回调函数中获取到的state值,为第一次运行时的内存中的state值。...而组件函数内的普通函数,每次运行组件函数中,普通函数与state的作用域链为同一层,所以会拿到最新的state值。

    11K60

    【C++】构造函数分类 ② ( 在不同的内存中创建类的实例对象 | 栈内存中创建实例对象 | new 关键字创建对象 )

    一、在不同的内存中创建类的实例对象 1、栈内存中创建实例对象 在上一篇博客 【C++】构造函数分类 ① ( 构造函数分类简介 | 无参构造函数 | 有参构造函数 | 拷贝构造函数 | 代码示例 - 三种类型构造函数定义与调用..., 会自动将栈内存中的实例对象销毁 ; 栈内存中 调用 构造函数 创建的 实例对象 , 不需要关注其内存占用 ; 2、堆内存中创建实例对象 在 栈内存 中声明 类 的 实例对象 方式是 : 该 s1...; Student* s2; 在 C++ 语言中 , 可以使用 new 关键字 , 调用有参构造函数 , 创建类的 实例对象 ; 在下面的 C++ 代码中 , 声明并定义了 MyClass 类 , 该类定义了一个有参构造函数..., 接受两个整数作为 构造函数参数 ; 在 main 函数中 , 使用 使用 new 关键字 来调用 有参构造函数 创建 MyClass 类实例对象 ; class MyClass { public...实例对象 , 则不需要关心 该对象 的内存占用情况 , 在这块代码块作用域结束时 , ( 一般是函数大括号内的代码执行完毕 ) , 该 栈内存 中的 MyClass 对象会被系统自动销毁 ; MyClass

    18820

    【Groovy】MOP 元对象协议与元编程 ( 使用 Groovy 元编程进行函数拦截 | 动态拦截函数 | 动态获取 MetaClass 中的方法 | evaluate 方法执行Groovy脚本 )

    文章目录 一、基础示例 二、根据字符串动态获取 MetaClass 中的方法 二、使用 evaluate 执行字符串形式的 Groovy 脚本 二、完整代码示例 一、基础示例 ---- 定义类 Student..., 并执行 Student 对象的 hello 方法 , def student = new Student(name: "Tom", age: 18) // 第一次调用 hello 方法 student.hello...() 执行结果如下 : Hello , my name is Tom, 18 years old 二、根据字符串动态获取 MetaClass 中的方法 ---- 进行动态函数拦截时 , 事先不知道要要拦截的方法名..., 这里声明一个药拦截的方法名变量 ; // 要拦截的方法名 def interceptMethodName = "hello" 使用如下代码操作 , 即可获取 MetaClass 中的方法 ; //...${interceptMethodName}" 二、使用 evaluate 执行字符串形式的 Groovy 脚本 ---- 动态函数拦截时 , 也不知道拦截后要执行哪些操作 , 使用 evaluate

    1.4K40

    C++核心准则​T.141:如果你需要只在一个地方使用的简单的函数对象,使用无名的lambda表达式

    T.141: Use an unnamed lambda if you need a simple function object in one place only T.141:如果你需要只在一个地方使用的简单的函数对象...,使用无名的lambda表达式 Reason(原因) That makes the code concise and gives better locality than alternatives....检索完全一致和差不多一致的lambda表达式(以便替换为命名函数或命名lamabda表达式) 原文链接 https://github.com/isocpp/CppCoreGuidelines/blob...这样一方面可以使读者了解真实的软件开发工作中每个设计模式的运用场景和想要解决的问题;另一方面通过对这些问题的解决过程进行说明,让读者明白在编写代码时如何判断使用设计模式的利弊,并合理运用设计模式。...对设计模式感兴趣而且希望随学随用的读者通过本书可以快速跨越从理解到运用的门槛;希望学习Python GUI 编程的读者可以将本书中的示例作为设计和开发的参考;使用Python 语言进行图像分析、数据处理工作的读者可以直接以本书中的示例为基础

    66820

    千万别再一直无脑使用ES6的箭头函数了,它虽然很有用但并不是万能的

    ES6函数扩展之箭头函数的详细介绍 引言 正文 一、箭头函数的基本使用 二、箭头函数的作用 三、箭头函数的注意点 (1)例子1 (2)例子2 (3)例子3 四、不宜使用箭头函数的场景 (1)定义类的方法...在这个例子中,我们在箭头函数中打印的arguments,最后返回的却是普通函数传入的实参内容,说明箭头函数内是没有arguments对象的。...四、不宜使用箭头函数的场景 在第三部分介绍了箭头函数的注意点以后,我们可以看到,有些时候使用箭头函数是不合适的。...() //返回 undefined 我们可以看到在定义类的方法时,我们使用了箭头函数,准备通过this.name获取obj中的name,最后返回了undefined。...我们可以看到,打印的是全局的window对象,因为箭头函数内没有自己的this,所以往上找,就直接找到了全局的window对象了。所以像这种情况,是不建议使用箭头函数的。

    80610

    我不知道的前端(三)

    和childNodes 一样,在Firefox下不支持()取集合元素。因此如果想获取指定元素的第一个HTML节点,可以使用children[0]来替代上面的getFirst函数。...: foo()被包含在对象内 foo()的调用前方有对obj的引用 显式绑定 这是非常直观的绑定方式、 function foo(){ ... } let obj={ a:2...的new操作符和传统面向对象的new并不一样; 我们用new调用函数就是所谓的构造 使用new来调用函数,会有如下操作: 创建一个全新的对象 新对象要执行[[Prototype]]连接 新对象绑定函数调用的...(bar.a); // 2 复制代码 ---- 不遵从this词法 我们上边说的并无问题,不过如果对于箭头函数,那么this的作用域又不一样 console.log=()=>{}; 这样是一个箭头函数...,而这样一个箭头函数的this实际上并不存在,箭头函数的this来自于它的上一层作用域

    30630

    js箭头函数

    引入箭头函数作用 引入箭头函数的作用:更简短的函数并且不绑定this 更简短的函数 let sum = (x,y,z) => { return x+y+z; } 不绑定this 在箭头函数出现之前,每个新定义的函数都有他自己的...(在构造函数的情况下是一个新对象,在严格模式的函数调用中为 undefined,如果该函数被作为“对象方法”调用则为基础对象等)。...(箭头函数中若用了this,这个this指向包裹箭头函数的第一个普通函数的 this。) 不绑定arguments 大多数情况下,使用剩余参数是相较于arguments对象的更好选择。...yield 关键字通常不能在箭头函数中使用(除非是嵌套在允许使用的函数内)。...返回对象字面量时 箭头函数返回简单值时可以简写成: let sum = ( x, y ) => x + y but返回对象字面量时不口以这样var func = () => {foo: 1},需要用圆括号括起来

    4.4K10

    如何修复Vue中的 “this is undefined” 问题

    在大多数情况下,我们应该在 Vue 中使用常规函数,特别是在创建时 methods computed props watched props 虽然常规函数通常是我们所需要的,但是箭头函数也非常方便。...this is undefined } } 简而言之,尽量避免在Vue组件上使用箭头函数。这将会省去许多头痛和困惑的问题。 有时使用箭头函数是很好的,但这只在不引用this的情况下才有效。...我们通常使用箭头函数有几个原因 更短、更简洁的语法 改善可读性 this 取自父类 在Vue方法中,箭头函数也可以作为匿名函数使用。...在获取数据时使用正确的函数 如果正在使用fetch或axios获取异步数据,最好使用 Promise。Promise喜欢匿名箭头函数,它们也使处理this问题变得容易得多。...某些编程语言只在程序运行时才确定作用域内的内容。这可能会让人很困惑,所以大多数语言都只使用词法作用域。 箭头函数使用词法作用域,而常规函数和简写函数不使用。

    5K20

    鸿蒙开发学习(一)之ArkTS

    箭头函数的定义如下,其函数是一个语句块: ( [param1, parma2,…param n] )=> { // 代码块 } 其中,括号内是函数的入参,可以有0到多个参数,箭头后是函数的代码块...模块里面的变量、函数和类等在模块外部是不可见的,除非明确地使用 export 导出它们。类似地,我们必须通过 import 导入其他模块导出的变量、函数、类等。...自定义组件中提供了一个build函数,开发者需在该函数内以链式调用的方式进行基本的UI描述,UI描述的方法请参考UI描述规范。...*装饰器:装饰器给被装饰的对象赋予某一种能力,其不仅可以装饰类或结构体,还可以装饰类的属性。多个装饰器可以叠加到目标元素上,定义在同一行中或者分开多行,推荐分开多行定义。...,不仅可以在组件内使用,还可以在不同组件层级间传递,比如父子组件之间、爷孙组件之间,也可以是全局范围内的传递。

    2.8K40

    Python核心编程的四大神兽

    对于迭代器来讲需要用next()方法来获取值,修改主函数为以下情况可以打印输出前4个整数的立方数: if __name__ == '__main__': G = lifang_generate()...图解:Python解释器从上往下解释代码,首先是函数定义,这时在计算机内存开辟了一片空间来存储这个函数,函数没有被执行,继续往下解释;到了主函数部分,首先执行蓝色箭头1,接着往下执行到蓝色箭头2第一次调用生成器取值...主函数中程序接着往下执行到蓝色箭头3,生成器函数lifang_generate()第二次被调用,与第一次不同,第二次从上一次(也就是第一次)暂停的位置继续往下执行,上一次停在了yield处,因此蓝色箭头...组合数据类型不是迭代器,但是属于可迭代对象,可以通过iter()函数将其转换位迭代器,这样就可以使用next方法来获取对象各个元素的值,代码如下: from collections import Iterable...图解:Python解释器从上往下解释代码,首先定义一个函数,func指向了该函数(红箭头所示);接着到主函数执行第14行代码 ret = func(10),此时先执行赋值号“=”右边的内容,这里调用了函数

    72630

    JS 中几种轻松处理’this’指向方式

    3.使用箭头函数 有没有办法在没有附加变量的情况下静态绑定this? 是的,这正是箭头函数的作用。...简单来说,它使用来自其定义的外部函数this的值。 建议在需要使用外部函数上下文的所有情况下都使用箭头函数。 4. 绑定上下文 现在让咱们更进一步,使用ES6中的类重构Person。...在类的情况下,使用附加的变量self或箭头函数来修复this的指向是行不通的。...这种方法是在类中绑定this的最有效和最简洁的方法。 6. 总结 与对象分离的方法会产生 this 指向不正确问题。静态地绑定this,可以手动使用一个附加变量self来保存正确的上下文对象。...然而,更好的替代方法是使用箭头函数,其本质上是为了在词法上绑定this。 在类中,可以使用bind()方法手动绑定构造函数中的类方法。

    1K20

    前端面试比较好的回答

    DNS同时使用TCP和UDP协议?DNS占用53号端口,同时使用TCP和UDP协议。 (1)在区域传输的时候使用TCP协议辅域名服务器会定时(一般3小时)向主域名服务器进行查询以便了解数据是否有变动。...obj的方法b是使用箭头函数定义的,这个函数中的this就永远指向它定义时所处的全局执行环境中的this,即便这个函数是作为对象obj的方法调用,this依旧指向Window对象。...但是由于箭头函数时没有自己的this的,且this指向外层的执行环境,且不能改变指向,所以不能当做构造函数使用。(6)箭头函数没有自己的arguments箭头函数没有自己的arguments对象。...在箭头函数中访问arguments实际上获得的是它外层函数的arguments值。...z-index 的使用是在有两个重叠的标签,在一定的情况下控制其中一个在另一个的上方或者下方出现。

    1K30

    前端开发面试题自测_2023-02-27

    解析: parent.show(),可以直接获得所需的值,没啥好说的; child1.show(),Child的构造函数原本是指向Child的,题目显式将Child类的原型对象指向了Parent类的一个实例...除了浏览器主窗⼝显示的您请求的⻚⾯外,其他显示的各个部分都属于⽤户界⾯。 浏览器引擎 在⽤户界⾯和呈现引擎之间传送指令。 呈现引擎 负责显示请求的内容。...箭头函数能当构造函数吗? 普通函数通过 function 关键字定义, this 无法结合词法作用域使用,在运行时绑定,只取决于函数的调用方式,在哪里被调用,调用位置。...(取决于调用者,和是否独立运行) 箭头函数使用被称为 “胖箭头” 的操作 => 定义,箭头函数不应用普通函数 this 绑定的四种规则,而是根据外层(函数或全局)的作用域来决定 this,且箭头函数的绑定无法被修改...[construct] 方法,创建一个实例对象,然后再执行这个函数体,将函数的 this 绑定在这个实例对象上 当直接调用时,执行 [Call] 方法,直接执行函数体 箭头函数没有 [Construct

    39620
    领券