当从箭头函数返回一个对象时,由于语法的模糊性,似乎有必要使用额外的一组{}
和一个return
关键字.
这意味着我不能写p => {foo: "bar"}
,但必须写p => { return {foo: "bar"}; }
.
如果箭头函数返回除对象以外的任何内容{}
,return
则不需要,例如:p => "foo"
.
p => {foo: "bar"}
回报undefined
.
修改后的p => {"foo": "bar"}
抛出" SyntaxError
:意外标记:' :
'".
有什么明显的东西我不见了吗?
规范问题如果在用箭头函数替换函数声明/表达式后发现有关问题的问题,请将其作为此副本的副本关闭.
ES2015中的箭头功能提供了更简洁的语法.我现在可以用箭头功能替换所有函数声明/表达式吗?我需要注意什么?
例子:
构造函数
function User(name) {
this.name = name;
}
// vs
const User = name => {
this.name = name;
};
Run Code Online (Sandbox Code Playgroud)
原型方法
User.prototype.getName = function() {
return this.name;
};
// vs
User.prototype.getName = () => this.name;
Run Code Online (Sandbox Code Playgroud)
对象(文字)方法
const obj = {
getName: function() {
// ...
}
};
// vs
const obj = {
getName: () => {
// ...
}
};
Run Code Online (Sandbox Code Playgroud)
回调
setTimeout(function() {
// ...
}, 500);
// vs
setTimeout(() => {
// ...
}, …
Run Code Online (Sandbox Code Playgroud) 我知道>=
运算符意味着大于或等于,但我=>
在一些源代码中看到过.那个运营商的意义是什么?
这是代码:
promiseTargetFile(fpParams, aSkipPrompt, relatedURI).then(aDialogAccepted => {
if (!aDialogAccepted)
return;
saveAsType = fpParams.saveAsType;
file = fpParams.file;
continueSave();
}).then(null, Components.utils.reportError);
Run Code Online (Sandbox Code Playgroud) 我一直在阅读一堆react
代码,我看到这样的东西,我不明白:
handleChange = field => e => {
e.preventDefault();
/// Do something here
}
Run Code Online (Sandbox Code Playgroud) 我可以用async
关键字将javascript函数标记为"async"(即返回一个promise).像这样:
async function foo() {
// do something
}
Run Code Online (Sandbox Code Playgroud)
箭头函数的等效语法是什么?
这个问题针对的是那些在即将到来的ECMAScript 6(Harmony)背景下已经考虑过代码风格并且已经使用过该语言的人.
有了() => {}
和function () {}
我们有两种非常相似的方法来编写ES6中的函数.在其他语言中,lambda函数通常通过匿名来区分自己,但在ECMAScript中,任何函数都可以是匿名的.这两种类型中的每一种都具有唯一的使用域(即,当this
需要明确地绑定或明确地不绑定时).在这些域之间存在大量的情况,其中任何一种符号都可以.
ES6中的箭头功能至少有两个限制:
new
this
在初始化时限制范围抛开这两个限制,箭头函数理论上几乎可以在任何地方替换常规函数.在实践中使用它们的正确方法是什么?是否应使用箭头功能,例如:
this
变量不可知,我们不创建对象.我正在寻找的是在ECMAScript的未来版本中选择适当的函数符号的指南.该指南需要明确,以便可以向团队中的开发人员讲授,并保持一致,这样就不需要从一个函数符号到另一个函数符号进行不断的重构.
javascript lambda ecmascript-harmony ecmascript-6 arrow-functions
即我该如何表达:
function *(next) {}
Run Code Online (Sandbox Code Playgroud)
带箭头.我已经尝试了所有我能想到的组合,而且我找不到任何关于它的文档.
(目前使用节点v0.11.14)
我有一个函数,我试图转换为ES6中的新箭头语法.它是一个命名函数:
function sayHello(name) {
console.log(name + ' says hello');
}
Run Code Online (Sandbox Code Playgroud)
有没有办法给它一个没有var语句的名字:
var sayHello = (name) => {
console.log(name + ' says hello');
}
Run Code Online (Sandbox Code Playgroud)
显然,我只能在定义之后使用此功能.如下:
sayHello = (name) => {
console.log(name + ' says hello');
}
Run Code Online (Sandbox Code Playgroud)
在ES6中有新的方法吗?
为什么这在Node.js
控制台中运行(在4.1.1和5.3.0中测试)但在浏览器中不起作用(在Chrome中测试)?此代码块应创建并调用记录的匿名函数Ok
.
() => {
console.log('Ok');
}()
Run Code Online (Sandbox Code Playgroud)
此外,虽然上述工作在Node中,但这不起作用:
n => {
console.log('Ok');
}()
Run Code Online (Sandbox Code Playgroud)
这不是:
(n) => {
console.log('Ok');
}()
Run Code Online (Sandbox Code Playgroud)
奇怪的是,当添加参数时,它实际上会SyntaxError
在立即调用的部分抛出一个.
arrow-functions ×10
javascript ×10
ecmascript-6 ×8
async-await ×1
function ×1
generator ×1
lambda ×1
node.js ×1
promise ×1
return ×1
syntax ×1