本篇文章主要给大家介绍javascript箭头函数和普通函数的区别,希望对需要的朋友有所帮助!
箭头函数——ES6中引入的一个新特性——支持用JavaScript编写简洁的函数。虽然普通函数和箭头函数的工作方式相似,但是它们之间有一些有趣的区别,如下所述。
语法
普通函数的语法:
let x = function function_name(parameters){
// 函数体
};
|
普通函数的例子:
let square = function(x){
return (x*x);
};
console.log(sqaure(9));
|
输出:
data:image/s3,"s3://crabby-images/21a29/21a29407c3bff548692449fc90ad32bede3a1a8c" alt="1555122318840589.png 4110ee3b0d87992e67478d685c122ac.png"
箭头函数的语法:
let x = (parameters) => {
// 函数体
};
|
箭头函数的例子:
var square = (x) => {
return (x*x);
};
console.log(square(9));
|
输出:
data:image/s3,"s3://crabby-images/332de/332de0ecc921c8e64171cb5d4d927c6e41e3845d" alt="1555122383608675.png 9ddf304c3c02a099dc9e13fd4b6de11.png"
使用this关键字
与普通函数不同,箭头函数没有自己的this。
例如:
let user = {
name: "GFG",
gfg1:() => {
console.log("hello " + this.name);
},
gfg2(){
console.log("Welcome to " + this.name);
}
};
user.gfg1();
user.gfg2();
|
输出:
data:image/s3,"s3://crabby-images/9fa1b/9fa1b9bb4cc3d8f8711a389ec7d8331b803f0a6d" alt="1555122417898542.png eb5921d567199f28ed1da722540e8cc.png"
arguments对象的可用性
arguments对象在箭头函数中不可用,但在普通函数中可用。
普通函数的例子:
let user = {
show(){
console.log(arguments);
}
};
user.show(1, 2, 3);
|
输出:
data:image/s3,"s3://crabby-images/436a0/436a0ef5ccf8d30ef174e44c9b4e342fc7d84d01" alt="1555122458477474.png ab6c1bd607f616f297937c97a18633b.png"
箭头函数的例子:
let user = {
show_ar : () => {
console.log(...arguments);
}
};
user.show_ar(1, 2, 3);
|
输出:
data:image/s3,"s3://crabby-images/a88fc/a88fc76ac483890416497742f8e695586dbda558" alt="1555122563785116.png 740c591e426e8894f09cddbe4143803.png"
使用new关键字
使用函数声明或表达式创建的普通函数是“可构造的”和“可调用的”。由于普通函数是可构造的,因此可以使用'new'关键字调用它们。但是,箭头函数只是“可调用”而不是可构造的。因此,在尝试使用new关键字构造不可构造的箭头函数时,我们将得到一个运行时错误。
普通函数的例子:
let x = function(){
console.log(arguments);
};
new x =(1,2,3);
|
输出:
data:image/s3,"s3://crabby-images/63bc5/63bc53d52c341d31a20ae109b6b0ef3c822738b8" alt="1555122605606467.png 62ac04d47ec237737d5e0230f41e309.png"
箭头函数的例子:
let x = ()=> {
console.log(arguments);
};
new x(1,2,3);
|
输出:
data:image/s3,"s3://crabby-images/791d0/791d0628fa404abcef61194ebb0ee2de6a18f558" alt="1555122649519435.png 99d45296ca4bcac4b60f271b3361e77.png"
(责任编辑:yang) |