【发布时间】:2019-02-22 01:49:44
【问题描述】:
我创建了一个连接redux的组件,并返回当前加载的item's名称作为导航标题。
但是当我尝试从此组件获取标题时,它会因以下错误而中断:
Error: `title` cannot be defined as a function in navigation options for `StockScreen` screen.
Try replacing the following:
{
title: ({ state }) => state...
}
with:
({ navigation }) => ({
title: navigation.state...
})
这是我的组件:
import { connect } from 'react-redux';
let Title = () => {
if(this.props.item === null || this.props.item === undefined, this.props.item === {}) {
return '';
}else{
return this.props.item.TradeName;
}
}
const mapStateToProps = state => ({
item: state.stockItem.item,
});
export default ConnectedTitle = connect(mapStateToProps)(Title);
这就是我尝试在我的反应导航堆栈中实现它的方式:
const Stack = createStackNavigator(
{
Home: {
screen: Tabs,
navigationOptions: {
header: null,
},
},
StockModal: {
screen: StockModal,
navigationOptions: {
header: null,
},
},
StockScreen: {
screen: StockScreen,
navigationOptions: {
headerRight: (<ConnectedSaveButton/>),
title: ConnectedTitle,
},
},
},
{}
);
【问题讨论】:
-
我不知道你想在这里实现什么。但是您应该使用 ConnectedTitle() 来运行该功能。试试标题:ConnectedTitle(),
-
我试过了,但我得到'不能将一个类称为函数'
标签: reactjs react-native redux react-redux react-navigation