<meta charset="UTF-8"> <script> /** * ES6允许使用“箭头”(=>)定义函数。 * */ var f1 = v => v; console.info(f1('f1')); //等同于 var f2 = function(v) { return v; }; console.info(f2('f2')); /** * 如果箭头函数不需要参数或需要多个参数 * 就使用一个圆括号代表参数部分。 * */ var f1_1 = () => 5; console.info(f1_1()); //等同于 var f1_2 = function() { return 5; }; console.info(f1_2()); var f2_1 = (a, b) => a + b; console.info(f2_1(7,8)); //等同于 var f2_2 = function f2_2(a, b) { return a + b; }; console.info(f2_2(7,8)); /** * 如果箭头函数的代码块部分多于一条语句,就要使用大括号将它们括起来,并且使用return语句返回。 * 由于大括号被解释为代码块,所以如果箭头函数直接返回一个对象,必须在对象外面加上括号。 * 箭头函数可以与变量解构结合使用。 * */ const f3_1 = ({ first, last }) => first + ' ' + last; console.info(f3_1({first:'时间',last:'城主'})); //等同于 var f3_2 = function f3_1(_ref) { var first = _ref.first; var last = _ref.last; return first + ' ' + last; }; console.info(f3_2({first:'吴',last:'者然'})); /** * 使用注意点 * 箭头函数有几个使用注意点。 * (1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。 * (2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。 * (3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用Rest参数代替。 * (4)不可以使用yield命令,因此箭头函数不能用作Generator函数。 * this指向的固定化,并不是因为箭头函数内部有绑定this的机制,实际原因是箭头函数根本没有自己的this,导致内部的this就是外层代码块的this。正是因为它没有this,所以也就不能用作构造函数。 * 除了this,以下三个变量在箭头函数之中也是不存在的,指向外层函数的对应变量:arguments、super、new.target。 * */ function f4_1() { setTimeout(() => { console.log('args:', arguments); }, 100); } f4_1(2, 4, 6, 8); //等同于 function f4_2() { var _arguments = arguments; setTimeout(function () { console.log('args:', _arguments); }, 100); } f4_2(2, 4, 6, 8); </script>
效果图:
相关推荐
JavaScript ES6箭头函数是一个来自ECMAScript 2015(又称ES6)的全新特性,有传闻说,箭头函数的语法=>,是受到了CoffeeScript 的影响,并且它与CoffeeScript中的=>语法一样,共享this上下
es6-arrow-function, shorthand 箭头函数编译为 ES5. es6-arrow-function 编译使用箭头函数编写的JavaScript以使用ES5-compatible函数语法。 例如:[1, 2, 3].map(n => n * 2);编译为:[1, 2, 3
es6箭头函数提供了一种更加简洁的函数书写方式
详解Javascript ES6中的箭头函数(Arrow Functions)_.docx
主要给大家总结了关于javascript ES6中箭头函数注意细节的相关资料,文中介绍的比较详细,需要的朋友可以参考借鉴,下面来一起看看吧。
等箭头功能 npm模块,以确定某个功能是否为ES6箭头功能。 注意:目前仅在Firefox中有效。例子var isArrowFunction = require ( 'is-arrow-function' ) ;assert ( ! isArrowFunction ( function ( ) { } ) ) ;assert ...
1.传统的javascript函数语法并没有提供任何的灵活性,每一次你需要定义一个函数时,你都必须输入function () {},这至少会出现两个问题,ES6箭头函数都圆满解决了它, 第一个问题:代码输入快了容易输错成 funciton...
箭头函数,若有了解过coffeeScript的同学,或许对此印象深刻,因为它可以让语法省略不少,特别是对于回调函数,会让代码更清晰简洁。下面让我们一起来学习学习ES6中的箭头函数。
ES6标准新增了一种新的函数:Arrow Function(箭头函数),为什么叫Arrow Function?因为它的定义用的就是一个箭头
javaScript中的箭头函数 箭头函数是ES6中新增的内容对于初学者来说可能会有很多疑惑,大括号和括号有什么区别呢?看了好多博客,讲的都是模棱两可,今天我来为大家献上干货,看完这个绝对能很好的掌握箭头函数。 首先...
ES6标准新增了一种新的函数:Arrow Function(箭头函数)箭头函数表面上相当于匿名函数,并且简化了函数定义。它们各自的区别是什么呢? 1 带名和匿名函数的区别 区别:匿名函数需要讲地址赋值给另一个变量let a,...
ES6标准新增了一种新的函数:Arrow Function(箭头函数)。那么下面这篇文章主要给大家介绍了箭头函数中this的相关资料,有需要的朋友可以参考借鉴,下面来一起看看吧。
本文介绍的是setTimeout函数,延迟执行函数里的执行上下文,分享给大家供大家参考学习,来看看详细的内容: (1)ES5中,setTimeout里面的函数的执行上下文为全局...(2)在ES6的箭头函数中,setTimeout里面,如果执行
ES6标准新增了一种新的函数:Arrow Function(箭头函数)。 为什么叫Arrow Function?因为它的定义用的就是一个箭头: x => x * x 上面的箭头函数相当于: function (x) { return x * x; } 在继续学习箭头...
介绍了javascript 中es6的一些语法以及ES5之间的区别,箭头函数 箭头函数的特殊性 解构数组
获取给定函数的参数名称(支持ES6箭头语法) 安装 使用安装function-params : npm install --save function-params 用法 模块使用 var functionParams = require ( 'function-params' ) ; functionParams ( ...