在我的 mapStateToProps
函数中,我将 idToken
和 accessToken
设置为存储在state中的值 . 这是有效的,因为我已经能够从组件中引用这些值 . 在 mapDispatchToProps
中,我尝试在我的动作中使用这些道具作为参数 . 但是, ownProps
是一个空对象 . 为什么没有 idToken
和 accessToken
?
容器:
import { connect } from 'react-redux'
import { toggleAddQuestionModal, fetchFriends } from '../actions'
import AddQuestionButtonComponent from '../components/AddQuestionButton'
const mapStateToProps = (state) => {
auth = state.auth
return {
idToken: auth.token.idToken,
accessToken: auth.profile.identities[0].accessToken,
}
}
const mapDispatchToProps = (dispatch, ownProps) => {
return {
didPress: (idToken, accessToken) => {
dispatch(toggleAddQuestionModal(true))
dispatch(fetchFriends(ownProps.idToken, ownProps.accessToken))
}
}
}
AddQuestionButton = connect(
mapStateToProps,
mapDispatchToProps
)(AddQuestionButtonComponent)
export default AddQuestionButton
零件:
'use strict';
import React, {
Text,
View,
TouchableHighlight,
PropTypes,
} from 'react-native'
import styles from './styles'
const AddQuestionButton = ({ didPress, idToken, accessToken }) => (
<TouchableHighlight style={styles.actionButton} onPress={didPress(idToken, accessToken)}>
<Text style={styles.actionButtonText}>+</Text>
</TouchableHighlight>
)
AddQuestionButton.propTypes = {
idToken: PropTypes.string.isRequired,
accessToken: PropTypes.string.isRequired,
didPress: PropTypes.func.isRequired,
}
export default AddQuestionButton
为什么我无法从 ownProps
访问 idToken
和 accessToken
?如果这种方式不正确,应该如何访问 idToken
和 accessToken
?
谢谢!
1 回答
在
mapStateToProps
和mapDispatchToProps
中,ownProps
参数引用组件通过属性接收的props,例如:<AddQuestionButton isVisible={ true } />
isVisible
属性将作为ownProps
传递 . 通过这种方式,您可以拥有一个从redux接收一些道具的组件,以及一些来自属性的道具 .connect方法本身有一个名为
mergeProps
的第三个参数:在合并道具中,你实际上可以将所有道具组合在一起,正如你在Dan Abramov的回答中所看到的那样issue: