JS ES6箭头函数

  1. <meta charset="UTF-8">  
  2. <script>  
  3. /** 
  4.  * ES6允许使用“箭头”(=>)定义函数。 
  5.  * */  
  6. var f1 = v => v;  
  7. console.info(f1('f1'));  
  8. //等同于  
  9. var f2 = function(v) {  
  10.   return v;  
  11. };  
  12. console.info(f2('f2'));  
  13.   
  14. /** 
  15.  * 如果箭头函数不需要参数或需要多个参数 
  16.  * 就使用一个圆括号代表参数部分。 
  17.  * */  
  18. var f1_1 = () => 5;  
  19. console.info(f1_1());  
  20. //等同于  
  21. var f1_2 = function() {  
  22.   return 5;  
  23. };  
  24. console.info(f1_2());  
  25.   
  26. var f2_1 = (a, b) => a + b;  
  27. console.info(f2_1(7,8));  
  28. //等同于  
  29. var f2_2 = function f2_2(a, b) {  
  30.   return a + b;  
  31. };  
  32. console.info(f2_2(7,8));  
  33.   
  34. /** 
  35.  * 如果箭头函数的代码块部分多于一条语句,就要使用大括号将它们括起来,并且使用return语句返回。 
  36.  * 由于大括号被解释为代码块,所以如果箭头函数直接返回一个对象,必须在对象外面加上括号。 
  37.  * 箭头函数可以与变量解构结合使用。 
  38.  * */  
  39. const f3_1 = ({ first, last }) => first + ' ' + last;  
  40. console.info(f3_1({first:'时间',last:'城主'}));  
  41. //等同于  
  42. var f3_2 = function f3_1(_ref) {  
  43.   var first = _ref.first;  
  44.   var last = _ref.last;  
  45.   return first + ' ' + last;  
  46. };  
  47. console.info(f3_2({first:'吴',last:'者然'}));  
  48.   
  49. /** 
  50.  * 使用注意点 
  51.  * 箭头函数有几个使用注意点。 
  52.  * (1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。 
  53.  * (2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。 
  54.  * (3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用Rest参数代替。 
  55.  * (4)不可以使用yield命令,因此箭头函数不能用作Generator函数。 
  56.  * this指向的固定化,并不是因为箭头函数内部有绑定this的机制,实际原因是箭头函数根本没有自己的this,导致内部的this就是外层代码块的this。正是因为它没有this,所以也就不能用作构造函数。 
  57.  * 除了this,以下三个变量在箭头函数之中也是不存在的,指向外层函数的对应变量:arguments、super、new.target。 
  58.  * */  
  59. function f4_1() {  
  60.   setTimeout(() => {  
  61.     console.log('args:', arguments);  
  62.   }, 100);  
  63. }  
  64. f4_1(2, 4, 6, 8);  
  65. //等同于  
  66. function f4_2() {  
  67.   var _arguments = arguments;  
  68.   setTimeout(function () {  
  69.     console.log('args:', _arguments);  
  70.   }, 100);  
  71. }  
  72. f4_2(2, 4, 6, 8);  
  73. </script>  

 

效果图:

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值