创建完整的导出react-native的索引文件

时间:2017-06-16 13:51:56

标签: react-native

是否有可能在本机中创建一个索引文件,您可以从中引用导入而不是执行'../../folder/component'?

我尝试过几种不同的方法,包括:

组件文件夹

Stack

index.js

-> chat
  -> Chat.js
-> dashboard
  -> Dashboard.js
-> home
  -> Home.js
-> index.js

然后在组件内部,让我们说Dashboard, import Home from './home/Home' import Dashboard from './dashboard/Dashboard' import Chat from './chat/Chat' module.exports = { Home, Dashboard, Chat, }

另一种方法:

index.js

import { Home, Chat } from '../components'

我还尝试用curlies围绕导出,ex export Home from './home/Home' export Dashboard from './dashboard/Dashboard' export Chat from './chat/Chat' ,因为编译器抛出了一个错误,但它仍然没有这样工作。

我也在此用户问题Requiring Modules in react-native

中尝试了该方法

这个功能在react-native中是否可行?

1 个答案:

答案 0 :(得分:8)

是的,有可能。执行以下操作。

从组件文件命名导出。

来自Home.js的

export { Home };

来自Chat.js

export { Chat };

来自Dashboard.js

export { Dashboard };

其中Home,Chat和Dashboard是相应文件中的组件名称。

现在在你的index.js中执行以下操作:

export * from './home/Home';
export * from './chat/Chat';
export * from './dashboard/Dashboard';

在其他文件中使用它们:

import { Home, Chat, Dashboard } from '../components'

更新1

如果您正在使用redux并想要导出连接到商店的组件,请使用以下内容:

将连接的组件存储在const变量中,如下所示:

const HomeComponent = connect(mapStateToProps, mapDispatchToProps)(Home)

然后像这样导出:

export { HomeComponent }