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

函数内部的this指向

2.this 2.1函数内部的this指向 这些 this 的指向,是当我们调用函数的时候确定的。调用方式的不同决定了this 的指向不同 一般指向我们的调用者. ?...2.2改变函数内部 this 指向 2.2.1 call方法 call()方法调用一个对象。简单理解为调用函数的方式,但是它可以改变函数的 this 指向 应用场景: 经常做继承....2.2.2 apply方法 apply() 方法调用一个函数。简单理解为调用函数的方式,但是它可以改变函数的 this 指向。...2.2.3 bind方法 bind() 方法不会调用函数,但是能改变函数内部this 指向,返回的是原函数改变this之后产生的新函数 如果只是想改变 this 指向,并且不想调用这个函数的时候,可以使用...2.2.4 call、apply、bind三者的异同 共同点 : 都可以改变this指向 不同点: call 和 apply 会调用函数, 并且改变函数内部this指向.

1.7K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    指向函数的指针

    指向函数的指针 程序中定义函数后,对程序进行编译时,编译系统为函数分配一段存储空间存储二进制代码,这段内存空间的起始地址(也称入口地址)称为函数的指针。...程序中可以定义一个指针变量,用来存放一个函数的起始地址,即该指针变量指向一个函数,称为函数指针变量。...函数指针变量定义的一般形式如下: 类型说明符(*指针变量名)(函数的形参列表); 说明: (1)函数指针变量可以指向函数满足两个条件:函数的返回值由上面“类型说明符”确定;函数的形参列表与上面...p2可以指向返回值类型为 double,形参是一个 double类型变量的函数。...例如上面两个函数指针变量通常写成如下形式 int(* pl)(int, int ); double(* p2)( double); (2)使用函数指针变量调用函数之前,必须使函数指针变量指向一个函数

    79710

    指向函数的指针

    当调用一个函数时出了通过函数名来调用之外,还可以通过指向函数的指针变量来调用。切记,和一切指针变量一样,一个指向函数的指针其初值也不能为空。因为它在使用之前必须被赋予一个真实的地址。...double result = 0.0; 22 result = func1(0.0,1.0); 23 printf("%g\n",result); 24 } 现在改写上面的代码,使用一个指向函数的指针变量来调用函数...(2)、(*p)两侧括号不能省,p先与*结合,表面是一个指针变量,在后面的()的内容结合,表示此指针变量指向函数而非变量,如果去掉,如:double *p()表示p()的返回类型是一个指向double型变量的指针...但对于指向函数的指针变量,它只能指向函数的入口处而无法指向函数中某条具体的指令,因此,对于p+n,p++等指针运算对于指向函数的指针没有意义。...如:double (*p)(double , double); 所以,通过以上的了解,我们知道了指向函数的指针的灵活性,一个指针变量可以调用多个不同的函数,这对于程序的优化和简化都起了很大的作用。

    1.3K60

    this 指向3 — 函数中的this

    本文继续讨论 this 指向 问题,今天讨论: 函数中的this 0 1 箭头函数 箭头函数忽略任何形式的this指向改变....当在严格模式下,test打印还是为window, test2 则打印undefined 箭头函数中的this ,不是谁调用就指向谁 示例2: obj.test=()=>{ console.log...this 作用域, 指向外层非箭头函数作用域的this 另注: 箭头函数一定不能是一个构造器....bind bind() 方法创建一个新的函数,在 bind() 被调用时,这个新函数的 this 被指定为 bind() 的第一个参数,而其余参数将作为新函数的参数,供调用时使用。...总结: call、apply、bind 三个方法都可以改变函数中this 的指向 call、apply :立即执行 bind 返回一个新函数 var obj={ name:'sunshine',

    31110

    7.4 指向函数的指针

    一、什么是函数指针 解释:存储空间的起始地址(又称入口地址)称为这个函数的指针 二、用函数指针变量调用函数 (1)通过函数名调用 (2)通过指针变量访问它所指向函数 三、定义和使用指向函数的指针变量...一般形式 类型名(*指针变量名)(函数参数表列) 注意: ①定义指向函数的指针变量,并不意味着这个指针变量可以指向任何函数,它只能指向在定义时指定的类型的函数 ②如果要用指针调用函数,必须先使指针变量指向函数...③在给函数的入口地址赋值时,只需给出函数名而不必给出参数 ④用函数指针变量调用函数时,只需将(*p)代替函数名即可,在(*p)之后的括号中根据需要写上实参 ⑤对指向函数的指针变量不能进行算术运算 ⑥用函数名调用的函数...,只能调用所指定的一个函数,而通过指针变量调用函数比较灵活,可以根据不同情况先后调用不同的函数 四、用指向函数的指针作函数参数 指向函数的指针变量的一个重要用途是把函数的地址作为参数传递到其他函数

    8403329

    箭头函数与this指向探究

    ——柴陵郁禅师 今天研究了下箭头函数与this,发现了一些挺好玩的特性 首先,我们在控制台输入上这段js var handler = { name :'handler', init...// init4: {name: 'handler', init: ƒ} } init3.apply(); }, }; handler.init(); 可以明显的看到,箭头函数是锁定了...this指向的,这里的箭头函数中的this都指向这个handler对象 而使用function声明的函数中的this永远指向外部的window对象 我们再到webpack构建的vue项目中尝试 printThis...options: {…}, _renderProxy: Proxy, _self: VueComponent, …} print6.call(); }; print5(); } 可以看到这里的箭头函数中的...this都为undefined 而使用function声明的函数仍然指向当前Vue组件实例 了解这个特性,能清楚this的具体指向,方便后续前端开发

    43310

    8.5 指向函数的指针

    2、可以定义一个指向函数的指针变量,用来存放某一函数的起始地址,这就意味着此指针变量指向函数。...3、例子 int (*p)(int,int); 定义p是一个指向函数的指针变量,它可以指向函数的类型为整型且有两个整型参数的函数。p的类型用int(*)(int,int)表示。...02 用函数指针变量调用函数 如果想调用一个函数,除了可以通过函数名调用以外,还可以通过指向函数的指针变量来调用该函数。...2、定义指向函数的指针变量,并不意味着这个指针变量可以指向任何函数,它只能指向在定义时指定的类型的函数。 3、如果要用指针调用函数,必须先使指针变量指向函数。...04 用指向函数的指针作函数参数 1、指向函数的指针变量的一个重要用途是把函数的地址作为参数传递到其他函数

    9263029

    This指向与改变This指向

    This指向与改变This指向 This 的指向 在 ES5 中,其实 this 的指向,始终坚持一个原理:this 永远指向最后调用它的那个对象。...改变 this 的指向 改变 this 的指向我总结有以下几种方法: 使用 ES6 的箭头函数函数内部使用 _this = this 使用 apply、call、bind new 实例化一个对象 例...箭头函数 箭头函数的 this 始终指向函数定义时的 this,而非执行时。...需要注意的是,指定的 this 值并不一定是该函数执行时真正的 this 值,如果这个函数处于非严格模式下,则指定为 null 或 undefined 时会自动指向全局对象(浏览器中就是window对象...result : obj; } 创建一个空对象 obj; 将新创建的空对象的隐式原型指向其构造函数的显示原型。

    1.2K20

    执行函数中改变 this 的指向以及方法

    所以,还是改成 执行函数中改变 this 的指向以及方法。 改变 this 的指向的方法和执行 bind,apply,call 都是执行函数时,用来改变 this 的指向。...为什么需要改变这个 this 的指向 需要改变这个 this 的指向,是因为原来的 this 被污染了,需要重新再进行 this 指向,因为,this 指向的是被调用的父级作用域,而如果函数在另一个函数里面执行的时候...,那么,这个 this 的指向的就是这个函数,而不是那个被执行函数原来的那个作用域。...this 的指向指向了 window,而 fighter.fire() 这个函数的执行 this是需要指向这个 fighter 的。...这个时候再次调用 fire 这个函数,就不需要再改变 this 的指向了,直接执行就可以。

    1.1K61

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

    结果分析说明 GetName函数是在全局环境中定义,所以直接调用函数this就指向了全局环境,所以输出Jack。...(注意函数不加后面()的时候,那时候就不是调用,那只是一个包含函数指针的变量) 由于函数执行环境变成了obj对象,所以this只想就指向了obj,所以自然就输出了“Tom”。...函数扩展this对象 es5提供了三个函数非继承的方法,可以直接改变this的指向,但是在书中说是扩充函数作用域,但是我认为改变this指向更贴切一点。...三个方法分别为:apply,call,bing,用法都比较简单,作用也都是改变函数的this指向,下面我就用代码来简单说明一下。...这三个方法功能都是相同,都是改变this指向,只是使用形式上有一点不同,大家可灵活运用。

    2.6K11

    ES6箭头函数中this指向谁?

    ES6箭头函数中this (1)默认指向定义它时,所处上下文的对象的this指向。...即ES6箭头函数里this的指向就是上下文里对象this指向,偶尔没有上下文对象,this就指向window (2)即使是call,apply,bind等方法也不能改变箭头函数this的指向 一些实例加深印象...(1)hello是全局函数,没有直接调用它的对象,也没有使用严格模式,this指向window function hello() { console.log(this); // window...obj,setTimeout箭头函数,this指向最近的函数的this指向,即也是obj const obj = { num: 10, hello: function () { console.log...perimeter是箭头函数,this应该指向上下文函数this的指向,这里上下文没有函数对象,就默认为window,而window里面没有radius这个属性,就返回为NaN。

    1.8K10

    JS回调函数中的 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默认是指向window的,因为本质上是在函数内callback,并没有.前的对象调用 如何解决: 使用箭头函数 1 2 var Bob={ 3 sname...this自动指向了回调函数外层的 this 。...this 指向的固定化,并不是因为箭头函数内部有绑定 this 的机制,实际原因是箭头函数根本没有自己的 this,导致内部的 this 就是外层代码块的 this。

    7.4K30
    领券