为什么ES6代码和ES5代码在Babel.js编译后有不同的结果?

ccf*_*ard 6 javascript ecmascript-6 babeljs

ES6代码:

let foo = 'outer';

function bar(func = x => foo){
    let foo = 'inner';
    console.log(func());
}
bar(); // outer
Run Code Online (Sandbox Code Playgroud)

结果是"外部".

Babel.js编译的ES5代码:

'use strict';

var foo = 'outer';

function bar() {
    var func = arguments.length <= 0 || arguments[0] === undefined ? function (x) {
        return foo;
    } : arguments[0];

    var foo = 'inner';
    console.log(func());
}
bar(); // inner
Run Code Online (Sandbox Code Playgroud)

结果是"外部".

我不知道他们为什么会有不同的结果.

Bak*_*kot 5

这是巴贝尔的一个错误.复杂参数列表中的表达式不应该能够在函数体中看到声明,但Babel生成的代码会在函数范围内计算默认参数,其中内部foo是可见的.

  • 添加了链接.(最初跳过它是因为babel的bugtracker非常糟糕.)有趣的是,bug中的代码就是这个问题中的代码,所以我担心我错过了这个问题的重点. (2认同)