我正在使用react-native-drawer软件包。我可以使用ref打开和关闭抽屉。我正在另一堂课上做。一切正常。但是,当我使用connect函数时,出现一条错误消息,提示“未定义不是对象(正在评估'this.drawer.open')”。
这仅在我使用connect()时发生
其他问题已指出在connect(mapStateToProps,null,null,{forwardRef:true})中使用{forwardRef:true}
这没有效果
我是本机反应的初学者,无法使用forwardRef解决此问题,请帮忙!
注意:当不使用redux时,代码可以正常工作
app.js
import React from 'react';
import { StyleSheet, Text, View, StatusBar } from 'react-native';
import { createAppContainer, createBottomTabNavigator,
createStackNavigator, createSwitchNavigator } from 'react-
navigation';
import { Provider } from 'react-redux';
import { store } from './src/redux/store/store';
import Drawer from 'react-native-drawer';
import Ionicons from 'react-native-vector-icons/Ionicons';
import FeedDrawerScreen from
'./src/screens/drawer/feedDrawerScreen';
import eventScreen from './src/screens/main/eventScreen';
import feedScreen from './src/screens/main/feedScreen';
import mediaScreen from './src/screens/main/mediaScreen';
import profileScreen from './src/screens/main/profileScreen';
import queryScreen from './src/screens/main/queryScreen';
import profileDetailScreen from
'./src/screens/stack/profileDetailScreen';
import questionDetailScreen from
'./src/screens/stack/questionDetailScreen';
const drawerStyles = {
drawer: { shadowColor: '#000000', shadowOpacity: 1,
shadowRadius: 10, borderRightWidth: 1, borderRightColor:
'#e6e6e6'},
main: {paddingLeft: 0},
}
const feedStack = createStackNavigator(
{
feed: {
screen: feedScreen,
navigationOptions: () => ({
headerTitleStyle: {fontSize: 18, fontWeight: '500'},
title: 'Home',
headerBackTitle: 'back',
}),
},
questionDetail: {
screen: questionDetailScreen,
navigationOptions: () => ({
headerTitleStyle: {fontSize: 18, fontWeight: '500'},
title: 'Details',
headerBackTitle: 'back',
}),
},
profileDetail: {
screen: profileDetailScreen,
navigationOptions: () => ({
headerTitleStyle: {fontSize: 18, fontWeight: '500'},
title: 'Profile',
headerBackTitle: 'back',
}),
},
},
{
headerLayoutPreset: 'center',
}
);
const tabs = createBottomTabNavigator(
{
Home : feedStack,
Media : mediaScreen,
Question : queryScreen,
Event : eventScreen,
Profile : profileScreen,
},
{
initialRouteName : 'Home',
defaultNavigationOptions: ({ navigation }) => ({
tabBarIcon: ({ focused, horizontal, tintColor }) => {
const { routeName } = navigation.state;
let IconComponent = Ionicons;
let iconName;
if (routeName === 'Home') {
iconName = 'ios-home';
} else if (routeName === 'Media') {
iconName = 'ios-images';
} else if (routeName === 'Question') {
iconName = 'ios-help';
} else if (routeName === 'Event') {
iconName = 'ios-calendar';
} else if (routeName === 'Profile') {
iconName = 'ios-person';
}
// You can return any component that you like here!
return <IconComponent name={iconName} size={25} color=
{tintColor} />;
},
}),
tabBarOptions: {
activeTintColor: '#000000',
labelStyle: {
fontSize: 12,
},
showLabel: true,
}
}
);
const AppContainer = createAppContainer(tabs);
export default class App extends React.Component {
render() {
return (
<Provider store={store}>
<Drawer
ref = {(ref) => {feedScreen._drawer = ref}}
type="static"
content={<FeedDrawerScreen />}
tapToClose={true}
openDrawerOffset={100}
styles={drawerStyles}
tweenHandler={Drawer.tweenPresets.parallax}
>
<View style={styles.maincontainer}>
<StatusBar color='white' barStyle='dark-content'/>
<AppContainer />
</View>
</Drawer>
</Provider>
);
}
}
const styles = StyleSheet.create({
maincontainer: {
flex: 1,
},
});
DrawerCode
<Provider store={store}>
<Drawer
ref = {(ref) => {feedScreen._drawer = ref}}
type="static"
content={<FeedDrawerScreen />}
tapToClose={true}
openDrawerOffset={100}
styles={drawerStyles}
tweenHandler={Drawer.tweenPresets.parallax}
>
<View style={styles.maincontainer}>
<StatusBar color='white' barStyle='dark-content'/>
<AppContainer />
</View>
</Drawer>
</Provider>
feedScreen.js
import React from 'react';
import { StyleSheet, Text, View } from 'react-native';
import Ionicons from 'react-native-vector-icons/Ionicons';
import { ScrollView, Image } from 'react-native';
import { connect } from 'react-redux';
import { Card } from 'react-native-elements';
import Icon from 'react-native-vector-icons/FontAwesome';
class feedScreen extends React.Component {
static navigationOptions = {
headerLeft: (
<Ionicons name='ios-menu' size={25} color='black'
style={{marginLeft:15}} onPress={()=>{this._drawer.open()}}/>
),
headerRight: (
<View style={{flexDirection: 'row', marginRight:15}}>
<Ionicons name='ios-search' size={25} color='black' />
<Ionicons name='ios-notifications' size={25}
color='black' style={{marginLeft:15}}/>
</View>
),
};
render() {
return (
<View style={styles.container}>
<Text>feed screen</Text>
</View>
);
}
}
const mapStateToProps = (state) =>{
return {
feed_list : state.main.feed
}
}
export default connect(mapStateToProps,null,null,{forwardRef:
true})(feedScreen);