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

Js箭头函数

Js箭头函数 箭头函数是ES6新增的语法,提供了一种更加简洁的函数书写方式,类似于匿名函数,并且简化了函数定义。 完整写法 完整写法类似于匿名函数,省略了function关键字。...this,在箭头函数函数体中使用this时,会取得其上下文context环境的this。...由于箭头函数没有自己的this指针,使用apply、call、bind仅能传递参数而不能动态改变箭头函数的this指向。...this指向,所以指向contextObj对象 s2为普通函数,可以改变this指向,所以this指向了调用者 */ 利用箭头函数的this指向特点可以解决一些问题,例如常见的回调函数this指向问题...var s = () => {}; console.log(s.prototype); // undefined 不能用作函数生成器 箭头函数不能用作Generator,yield关键字通常不能在箭头函数中使用

4.9K20

js箭头函数

箭头函数 箭头函数表达式没有自己的this,arguments,super或new.target。...引入箭头函数作用 引入箭头函数的作用:更简短的函数并且不绑定this 更简短的函数 let sum = (x,y,z) => { return x+y+z; } 不绑定this 在箭头函数出现之前,每个新定义的函数都有他自己的...(在构造函数的情况下是一个新对象,在严格模式的函数调用为 undefined,如果该函数被作为“对象方法”调用则为基础对象等)。...(箭头函数若用了this,这个this指向包裹箭头函数的第一个普通函数的 this。) 不绑定arguments 大多数情况下,使用剩余参数是相较于arguments对象的更好选择。...箭头函数不能使用new操作符 箭头函数不能用作构造器,和 new一起用会抛出错误。

4.4K10
您找到你想要的搜索结果了吗?
是的
没有找到

js 箭头函数详解

认识箭头函数 es6 新增了使用胖箭头(=>)语法定义函数表达式的能力,很大程度上,箭头函数实例化的函数对象与正式的函数表达式创建的函数对象行为是相同的。...省略包含函数体的大括号 箭头函数也可以不用大括号,但这样会改变函数的行为。使用大括号就说明包含“函数体”,可以在一个函数包含多条语句,跟常规的函数一样。...(1, 2); // Uncaught ReferenceError: arguments is not defined 虽然箭头函数没有 arguments 对象,但可以在包装函数把它提供给箭头函数...箭头函数this 指向 let num = 11; const obj1 = { num: 22, fn1: function() { let num = 33;...:22 原因箭头函数没有this,箭头函数的this是继承父执行上下文里面的this ,这里箭头函数的执行上下文是函数fn1(),所以它就继承了fn1()的this,obj1调用的fn1,所以fn1的this

1.2K10

js匿名函数箭头函数_函数式编程

js匿名函数箭头函数,以及他们的区别 匿名函数 箭头函数 区别 1.匿名函数 简单点说就是没有名字的函数,在声明函数时不写函数名称,(将函数赋值给变量)叫匿名函数。...// 将函数赋值给变量,通过变量调用 var fn = function(){ console.log("hello js"); } fn(); //输出 hello js 2.箭头函数...箭头函数表面上相当于匿名函数,并且简化了函数定义。...')}; var y = ()=>{ console.log('箭头函数')}; x(); y(); 本质上都是函数箭头函数是匿名函数的简写形式。...箭头函数: 1.没有prototype(原型),所以箭头函数本身没有this。 2.不能当作构造函数,即不能使用new命令。 3.不能使用arguments对象,函数体内不存在该对象。

1.8K10

通过vue.js 学习来总结es6语法箭头函数箭头函数原理分析。

:Arrow Function(箭头函数)。...因为它的定义用的就是一个箭头: x => x * x 上面的箭头函数相当于: function (x) { return x * x; } 箭头函数相当于匿名函数,并且简化了函数定义。...由于this在箭头函数已经按照词法作用域绑定了,所以,用call()或者apply()调用箭头函数时,无法对this进行绑定,即传入的第一个参数被忽略: var obj = { birth:...// alert(this) // var fn = ()=>{ // this.msg ="222" // console.log(this) //箭头函数...) // } //---总结--- //箭头函数一般用于函数嵌套时,防止this指向变化,在箭头函数 //this的指向一直是外层对象,即廖雪峰大神说的“箭头函数完全

1.5K20

JavaScript箭头函数

你可以把函数存储在变量,把它们作为参数传递给其他函数,并从其他函数把它们作为值返回。你可以使用JavaScript箭头函数来做所有这些事情。 无圆括号语法 在上述示例函数是没有参数的。...下面的orderByLikes()函数返回奈飞剧集对象的数组,按照最高点赞数排序: // using the JS sort() function to sort the titles in descending...因此,函数处理器的this也被绑定到全局作用域中--也就是Window对象。 因此,如果你想让this引用程序的开始按钮,正确的做法是使用一个常规函数,而不是一个箭头函数。...匿名箭头函数 在上面的演示,接下来要注意的是.setInterval()方法的代码。在这里,你也会发现一个匿名函数,但这次是一个箭头函数。为什么?...这意味着arguments对象在箭头函数是不可用的。

2K20

javascript js(=>) 箭头函数 详细解说 案例大全

ES6标准新增了一种新的函数:Arrow Function(箭头函数)。 为什么叫Arrow Function?...因为它的定义用的就是一个箭头: x => x * x 上面的箭头函数相当于: function (x) { return x * x; } 箭头函数相当于匿名函数,并且简化了函数定义。...=> ({ foo: x }) this 箭头函数看上去是匿名函数的一种简写,但实际上,箭头函数和匿名函数有个明显的区别:箭头函数内部的this是词法作用域,由上下文确定。...如果使用箭头函数,以前的那种hack写法: var that = this; 就不再需要了。...由于this在箭头函数已经按照词法作用域绑定了,所以,用call()或者apply()调用箭头函数时,无法对this进行绑定,即传入的第一个参数被忽略: ?

1.3K40

箭头函数

箭头函数(★★★) ES6新增的定义函数的方式。...() => {} //():代表是函数; =>:必须要的符号,指向哪一个代码块;{}:函数体 const fn = () => {}//代表把一个函数赋值给fn 函数只有一句代码,且代码的执行结果就是返回值...this关键字,箭头函数的this,指向的是函数定义位置的上下文this const obj = { name: '张三'} function fn () { console.log(...fn里面,而这个fn指向是的obj对象,所以这个this也指向是obj对象 } } const resFn = fn.call(obj); resFn(); ​ 小结 箭头函数不绑定...this,箭头函数的this指向是它所定义的位置,可以简单理解成,定义箭头函数的作用域的this指向谁,它就指向谁 箭头函数的优点在于解决了this执行环境所造成的一些问题。

1.1K20

js this问题和es6箭头函数this问题

JSthis的四种用法 1.在一般函数方法中使用 this 指代全局对象 function test(){     this.x = 1;     alert(this.x);   }   test(...如果把最后一行代码修改为   o.m.apply(o); //1 ES6箭头函数与普通函数this的区别 普通函数的this: 1. this总是代表它的直接调用者, 例如 obj.func ,那么...undefined 4.使用call,apply,bind(ES5新增)绑定的,this指的是 绑定的对象 箭头函数的this 默认指向在定义它时,它所处的对象,而不是执行时的对象, 定义它的时候,可能环境是...,this指向了window(匿名函数,没有调用的宿主对象),而window对象并没有num属性(num属性在obj定义),而在使用箭头函数的情况下,this的指向却对象obj1,自然可以输出obj1...,如果没有被对象调用,函数的this就绑定的window上 }); } f(); } } obj1.fn(); 总结: 1.箭头函数的this绑定看的是this所在的函数定义在哪个对象下

1.3K30

揭秘箭头函数

如果您还没有阅读 JavaScript 函数表达式,我建议您在继续阅读之前先阅读这篇文章。 现在,让我们试着从语法、执行、作用域和提升以及代码示例方面来理解箭头函数。 1....我们可以看到箭头函数类似于函数表达式,因为它们被赋值为变量。...主要区别在于函数的编写方式。 以下是我们可以根据其语法从上述代码得出的观察结果: 它不包含 function 关键字。 它没有 函数名 ,这意味着这些是匿名函数。 引入了箭头 => 符号。...当 JS 引擎执行 arrowFunctionExecution() 时,它会创建一个函数,执行上下文并被推送到调用堆栈。 一旦创建了执行上下文,它就会启动创建阶段。...在这个阶段,它将创建参数对象并在其本地内存堆声明所有变量。 与普通函数相比,主要区别在于 this 的声明。 箭头函数没有自己的 this 变量; this 在箭头函数中使用时会得到词法解析。

1.1K20

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券