温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

js箭头函数和普通函数的区别是什么

发布时间:2020-09-16 09:42:33 来源:亿速云 阅读:282 作者:小新 栏目:web开发

这篇文章将为大家详细讲解有关js箭头函数和普通函数的区别是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

箭头函数——ES6中引入的一个新特性——支持用JavaScript编写简洁的函数。虽然普通函数和箭头函数的工作方式相似,但是它们之间有一些有趣的区别,如下所述。

语法

普通函数的语法:

let x = function function_name(parameters){ 
   // 函数体
};

普通函数的例子:

let square = function(x){ 
  return (x*x); 
}; 
console.log(sqaure(9));

输出:

js箭头函数和普通函数的区别是什么

箭头函数的语法:

let x = (parameters) => { 
    // 函数体
};

箭头函数的例子:

var square = (x) => { 
    return (x*x); 
}; 
console.log(square(9));

输出:

js箭头函数和普通函数的区别是什么

使用this关键字

与普通函数不同,箭头函数没有自己的this。

例如:

let user = { 
    name: "GFG", 
    gfg1:() => { 
        console.log("hello " + this.name); 
    }, 
    gfg2(){        
        console.log("Welcome to " + this.name); 
    }   
 }; 
user.gfg1(); 
user.gfg2();

输出:

js箭头函数和普通函数的区别是什么

arguments对象的可用性

arguments对象在箭头函数中不可用,但在普通函数中可用。

普通函数的例子:

let user = {       
    show(){ 
        console.log(arguments); 
    } 
}; 
user.show(1, 2, 3);

输出:

js箭头函数和普通函数的区别是什么

箭头函数的例子:

let user = {      
        show_ar : () => { 
        console.log(...arguments); 
    } 
}; 
user.show_ar(1, 2, 3);

输出:

js箭头函数和普通函数的区别是什么

使用new关键字

使用函数声明或表达式创建的普通函数是“可构造的”和“可调用的”。由于普通函数是可构造的,因此可以使用'new'关键字调用它们。但是,箭头函数只是“可调用”而不是可构造的。因此,在尝试使用new关键字构造不可构造的箭头函数时,我们将得到一个运行时错误。

普通函数的例子:

let x = function(){ 
    console.log(arguments); 
}; 
new x =(1,2,3);

输出:

js箭头函数和普通函数的区别是什么

箭头函数的例子:

let x = ()=> { 
    console.log(arguments); 
}; 
new x(1,2,3);

输出:

js箭头函数和普通函数的区别是什么

关于js箭头函数和普通函数的区别是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI