admin管理员组文章数量:1136158
Previously I could do:
import foo = require('foo');
But now that TypeScript (1.5) supports es6 module syntax, what is the correct way to achieve the same in ES6 module syntax.
Previously I could do:
import foo = require('foo');
But now that TypeScript (1.5) supports es6 module syntax, what is the correct way to achieve the same in ES6 module syntax.
Share Improve this question asked Apr 13, 2015 at 1:39 basaratbasarat 276k60 gold badges472 silver badges526 bronze badges 1- 3 There is quite a detailed discussion here 2ality.com/2014/09/es6-modules-final.html – user5321531 Commented Apr 13, 2015 at 3:20
6 Answers
Reset to default 112The correct way is to continue using the old import syntax. The new import syntax is for ES modules only, the old import syntax is for pre-ES6 modules. The two are distinct, intentionally so. import * as foo from 'foo'
imports all the properties of the module 'foo', it does not import the default value as foo
.
From the designer of the feature:
- An export default declaration always declares an exported member named default and is always emitted as an assignment to exports.default. In other words,
export default
consistently has ES module semantics. For compatibility with Babel we could optionally emit an__esModule
marker when a module has a default export, but we wouldn't actually use that marker for anything. - An
export =
declaration, which substitutes a different entity to be exported in place of the module itself, is always emitted as an assignment tomodule.exports
. It is an error to have other exports in a module that usesexport =
. This is the existing TypeScript behavior. - A module that uses
export =
to export another module (be that an internal or external module) can be imported using the new ES6 constructs. In particular, the convenient destructuring imports can be used with such modules. The pattern of usingexport =
to export another module is common in .d.ts files that provide a CommonJS/AMD view of an internal module (e.g. angular.d.ts). - A module that uses
export =
to export a non-module entity in place of the module itself must be imported using the existingimport x = require("foo")
syntax as is the case today.
2016 update: The TypeScript compiler at some point started allowing import * as foo from 'legacy-module-foo'
to get the default import of a legacy module in certain circumstances. This is a violation of the ES6 specification (§15.2.1.16, “The value "*" indicates that the import request is for the target module’s namespace object.”).
When legacy modules you import in this manner are updated to ES6 modules, the “default” imports for those modules will stop working (because * as foo
imports are supposed to be importing namespace objects), which may be extremely confusing if you don’t know that doing this is a TypeScript/SystemJS hack. It is also possible that a future TypeScript realignment to the ES specification will cause them to break.
As such, you should probably prefer to continue to use the legacy import syntax described above to load legacy modules to avoid confusing yourself and other developers working on your code about how ES6 namespace imports work, and to avoid confusing breaking changes.
The corresponding syntax for ES6 module syntax is:
import * as foo from 'foo';
Basically import everything from the foo
module into a local variable by the name of foo
.
As of TypeScript 2.7, there is a new esModuleInterop
flag that can be used to enable default imports with CommonJS/AMD/UMD. By setting that flag to true
in your tsconfig.json
, this should work as expected:
import foo from 'foo';
to import all ,
const foo = require("foo");
this will import all instance from package "foo" if its a file then
const foo = require("./foo");
so you can access each instance by calling, foo.InstanceName
if you want to import specific instance,
import MyInstance from "foo";
so this will import specific instance (Myinstance) from "foo" you can still import all using above method,
import * as ReferenceName from "foo";
its equivalent to,
const ReferenceName = require("foo");
ES6 modules are effectively TypeScript external modules with a new syntax: ES6 modules are separately loaded source files that possibly import other modules and provide a number of externally accessible exports. ES6 modules feature several new export and import declarations. It is recommended that TypeScript libraries and applications be updated to use the new syntax, but this is not a requirement.
Source
As far as I understand, that means that you are encouraged to migrate your own TypeScript modules to the new syntax, but keep using import foo = require('foo')
for importing actual AMD/CommonJS modules.
Another option is to import it using CommonJS syntax:
const foo = require("foo");
TypeScript and Babel both agree on what to do with this. Also, if you're compiling down to ES5 or less anyway, then this won't be too far off from its final form.
版权声明:本文标题:javascript - New es6 syntax for importing commonjsamd modules i.e. `import foo = require('foo')` - Stack Overflo 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1736943530a1957194.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论