【问题标题】:ExNavigation : how to pass props to all router components?ExNavigation:如何将道具传递给所有路由器组件?
【发布时间】:2016-10-12 23:20:03
【问题描述】:

在以下代码中,将数据库变量作为 props 传递给 Router/NavigationProvider 服务的所有组件的最佳方法是什么?

import {
  createRouter,
  NavigationProvider,
  StackNavigation,
} from '@exponent/ex-navigation'

const Router = createRouter(() => ({
  jobs: () => Jobs,
  sample: () => Sample
}))

render () {
  const database = this.openDatabase()
  <NavigationProvider router={Router}>
        <StackNavigation initialRoute={Router.getRoute('home')} />
  </NavigationProvider>
}

谢谢!

【问题讨论】:

  • 您是否以某种方式解决了这个问题?我正在尝试使用 ex-navigation component 实现相同的目标。如果你能分享一些 sn-ps 会有所帮助。
  • 在这种情况下,接受的答案为我解决了这个问题。只需创建一个文件(services/database.js)并在需要时导入数据库实例
  • @chrichards:我明白了,谢谢!

标签: react-native exponentjs


【解决方案1】:

您应该创建一个新的 javascript 文件,用于导出您的数据库连接并将其导入您希望使用的组件中。

您还可以创建高阶组件,将数据库连接作为组件的道具。这类似于 ExNavigation 中内置的 withNavigation 或 Redux 的 React 绑定附带的 connect

然而,由于 HOC 是一个有点高级的话题(但不难掌握!)这里是一个没有它的例子。

services/database.js

// Open database connection here and export it like any other module.
// The following is pseudo code to illustrate example

import { database } from 'database'
export default database.connect()

routes.js

import Jobs from './containers/Jobs'
import Sample from './containers/Sample'
import { createRouter } from '@exponent/ex-navigation'

const Router = createRouter(() => ({
  jobs: () => Jobs,
  sample: () => Sample
}))

export default Router

App.js

import React from 'react'
import {
  NavigationProvider,
  StackNavigation,
} from '@exponent/ex-navigation'

const App = () => (
  <NavigationProvider router={Router}>
     <StackNavigation initialRoute={Router.getRoute('home')} />
  </NavigationProvider>
)

export default App

容器/Jobs.js

import React, { Component } from 'react'

// Import database connection in every container component you wish to use it
import databaseConnection from '../services/database'

export default class Jobs extends Component {
  state = {
    jobs: []
  }

  componentDidMount() {
    databaseConnection
      .get('jobs')
      .then(jobs => this.setState({ jobs }))
  }

  render() {
    return (
      {this.state.jobs.map(job =>
        // Render jobs
      )}
    )
  }
}

【讨论】:

  • 谢谢。我熟悉 HOC 以及 redux 的工作原理。你是对的,你的例子是最简单的方法。我只是想知道我是否错过了某种 passProps 选项,就像我在其他路由器中使用的那样。
  • 但在您的示例中,您不是作为道具传递,而是从子组件访问databaseConnection。如何从App 组件传入?
  • 是的,这不是一个真正的答案。如果你想作为道具通过(我也有我想这样做的情况),似乎前导航对你没有答案。
猜你喜欢
  • 1970-01-01
  • 2020-03-26
  • 2020-04-03
  • 2017-05-29
  • 2020-04-07
  • 2015-09-01
  • 2021-04-12
  • 1970-01-01
  • 2019-05-01
相关资源
最近更新 更多