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

javascript - When should I use brackets with imports - Stack Overflow

programmeradmin4浏览0评论

I have two file, the first one is todoHelper.js

it has export const addTodo = (list, item) => [...list, item]

later on I want to use addTodo in another file, I simply do import {addTodo} from './todoHelpers'

But I'm also seeing people doing export default instead of just export. What's the differences?

I have two file, the first one is todoHelper.js

it has export const addTodo = (list, item) => [...list, item]

later on I want to use addTodo in another file, I simply do import {addTodo} from './todoHelpers'

But I'm also seeing people doing export default instead of just export. What's the differences?

Share Improve this question edited Mar 14, 2018 at 9:54 Shubham Khatri 282k58 gold badges430 silver badges411 bronze badges asked Feb 5, 2017 at 12:11 Zea LithZea Lith 4211 gold badge7 silver badges15 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 17

You can have only one export default per file and hence when you do export default like

export default AddTodo = (list, item) => [...list, item]

You can import it like

import MyAddTodo from './todoHelpers'

Since babel knows that you are trying to access the default ponent, you can access it in you file by any name

Now suppose you do

export const AddTodo = (list, item) => [...list, item]

You can have multiple such exports in you file like

export const AddTodo = (list, item) => [...list, item]  
export const DeleteTodo = (list, item) => [...list, item]

and when you import you will need to destructure them like

import {AddTodo, DeleteTodo} from './todoHelpers'

Now since you have multiple such exports thus babel wont know which ponent you are tyring to access if you access if by a different name like

import {MyAddTodo, MyDeleteTodo} from './todoHelpers'

If you want to do this you will have to import them as it is and them change thier name like

import {AddTodo as MyAddTodo, DeleteTodo as MyDeleteTodo} from './todoHelpers'

So as general practice you will default export the main ponent and the rest you can have as export normally or when you have only one ponent that you need to export from a file then you can choose whatever you want but a nice way will be to export it as default.

Using default keyword with export gives us the liberty to import with alias name

export default k // in file my.js

can be imported with alias name 'b'

import b from 'my.js'
发布评论

评论列表(0)

  1. 暂无评论