'require' 与 'import' es6 有何不同?

How does 'require' operates differently from 'import' es6?

我遇到了一种我无法解释的行为。 根据使用 importrequire,此测试成功 (import) 或失败 (require)。

如果失败,我有以下错误:

PhantomJS 2.1.1 (Windows 7 0.0.0) immutability a number is immutable FAILED undefined is not a constructor (evaluating 'expect((0, _immutable.List)([1])).toEqualImmutable((0, _immutable.List)([1]))')

代码如下:

import { Map, List } from 'immutable';
const expect = require("expect");
// import expectImmutable from "expect-immutable";
const expectImmutable = require("expect-immutable");

expect.extend(expectImmutable);

describe("immutability", () => {
    describe("a number", () => {
        function increment(currentState) {
            return currentState + 1;
        }
        it("is immutable", () => {
            expect(List([1])).toEqualImmutable(List([1]));
            expect(Map({ a: 1 })).toEqualImmutable(Map({ a: 1 }));
            let state = 42;
            let nextState = increment(state);

            expect(List([nextState])).toEqualImmutable(List([43]));
            expect(List([state])).toEqualImmutable(List([42]));
        });
    });
});

有人对幕后发生的事情有解释吗?

感谢@zerkms 和@maioman,你们的建议真的很有帮助。 @maioman 你是对的,这是由于库使用的导出语法。

es6 :

export default foo;

要求:

module.exports = foo;

所以当需要要求一个es6写的导出时,我们应该处理default关键字。

require("foo").default;