onestopweb 阅读(104) 评论(0)
<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>

 

效果图:

 

 

 

 

 

 

 

 

 

 

 

  • 大小: 21.3 KB