最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Re-Exporting entire module in ES6Babel - Stack Overflow

programmeradmin4浏览0评论

Let's say I have a module I want to re-export:

//exportme.js
export default 'EXPORTME';
export const test = () => console.log('test function');

//reexport.js
export * from './exportme.js'

When I import reexport.js, the default from exportme.js is not available.

//app.js
import reexport from './reexport.js'

console.log(reexport) //undefined

I have to make reexport.js to be the following for it to work.

export * from './exportme.js'
export default from './exportme.js'

Is there an easier way to do this or can this be consolidated into one statement?

export default, * from './exportme.js' does not work.

I am using latest babel with transform-export-extensions

Let's say I have a module I want to re-export:

//exportme.js
export default 'EXPORTME';
export const test = () => console.log('test function');

//reexport.js
export * from './exportme.js'

When I import reexport.js, the default from exportme.js is not available.

//app.js
import reexport from './reexport.js'

console.log(reexport) //undefined

I have to make reexport.js to be the following for it to work.

export * from './exportme.js'
export default from './exportme.js'

Is there an easier way to do this or can this be consolidated into one statement?

export default, * from './exportme.js' does not work.

I am using latest babel with transform-export-extensions

Share edited Oct 15, 2016 at 16:59 Michał Perłakowski 92.7k30 gold badges163 silver badges187 bronze badges asked Sep 29, 2016 at 21:01 wlingkewlingke 4,7994 gold badges37 silver badges52 bronze badges 1
  • Related Babel Github ticket – vsync Commented May 19, 2019 at 10:34
Add a ment  | 

2 Answers 2

Reset to default 5

The default from exportme.js is not available

Yes, default exports are not re-exported by star exports. The purpose of export * from … is to allow re-exports from multiple modules, exporting the default from multiple modules would only lead to collisions. You therefore have to specifiy it explicitly (if you need it at all, often there is no default export alongside named exports).

Is there an easier way to do this or can this be consolidated into one statement?

No, the two lines you have are the way to go.

As Bergi wrote, there is no way to do this in one line using ES 6 exports. You can, however, simply require the module you want to re-export and assign the result to module.exports:

module.exports = require('./exportme.js')
发布评论

评论列表(0)

  1. 暂无评论