【问题标题】:How to Refresh previous Drawer Screen calling from 2nd Screen in Drawer navigation in React-native?如何在 React-native 的抽屉导航中刷新从第二个屏幕调用的前一个抽屉屏幕?
【发布时间】:2019-04-12 01:37:03
【问题描述】:

在我的 React-Native 项目中,我使用了一个导航抽屉。在那个抽屉中,我声明了两个屏幕 - NoteMeHomeMakeNoteNoteMeHome 最初是作为抽屉导航的初始路径开始的。从 NoteMeHome.js(第一个屏幕)类我转到 MakeNote.js(第二个屏幕)。在这个 MakeNote.js 类中,我使用了一个表单来填写。用户 clikcs 提交时填写表单后,它将返回到上一个屏幕 ( NoteMeHome.js) 并且由于在此 NoteMeHome.js 类中有 API 调用,它将刷新并显示提交的数据。

但是每当我从 MakeNote 屏幕转到 NoteMeHome 屏幕时,它只会更改为返回堆栈,但 NoteMeHome 屏幕不会刷新因为它显示的是旧数据。

为了控制 Drawer 的流程和结构,我创建了一个名为 - 的类

NavigationDrawerStructure.js

class NavigationDrawerStructure extends Component {
  static navigationOptions = {
    header: null ,
  };

  toggleDrawer = () => {
    this.props.navigationProps.toggleDrawer();
  };
  render() {
    return (
      <View style={{ flexDirection: 'row' }}>
        <TouchableOpacity onPress={this.toggleDrawer.bind(this)}>
          {/*Donute Button Image */}
         <Icon name='menu'/>
        </TouchableOpacity>
      </View>
    );
  }
}
const FirstActivity_StackNavigator = createStackNavigator({
  First: {
    screen: NoteMeHome,
    navigationOptions: ({ navigation }) => ({
      title: 'Home',
      headerLeft: <NavigationDrawerStructure navigationProps={navigation} />,

      headerStyle: {
        backgroundColor: '#FF9800',
      },
      headerTintColor: '#fff',
    }),
  },

});

const Screen2_StackNavigator = createStackNavigator({
  Second: {
    screen: MakeNote,
    navigationOptions: ({ navigation }) => ({
      title: 'Create Note',
      headerLeft: <NavigationDrawerStructure navigationProps={navigation} />,

      headerStyle: {
        backgroundColor: '#FF9800',
      },
      headerTintColor: '#fff',
    }),
  },
});



const Drawer = createDrawerNavigator({
  Screen1: {
    screen: FirstActivity_StackNavigator,
    navigationOptions: {
      drawerLabel: 'Home',

      drawerIcon: (
        <Icon name='home' size={24}

        />
      )

    },
  },

  Screen2: {
    screen: Screen2_StackNavigator,
    navigationOptions: {
      drawerLabel: 'Create Note',
      drawerIcon: (
        <Icon name='home' size={24}

        />
      )
    },
  },

});

const DrawerNavigatorExample = createStackNavigator({
  Drawer: { screen: Drawer, navigationOptions: { header: null } },
  ScreenExternal: {
    screen: ScreenExternal,
    navigationOptions: { title: 'Screen External' },
  },
});

export default createAppContainer(DrawerNavigatorExample);

MakeNote.js(第二个屏幕)中,我使用一个函数提交 POST 请求。这是代码-

submit() {
    this.setState({isLoading:true})
    let collection = {}
    collection.timestamp = this.state.timestamp,
    collection.status = this.state.status,
    collection.title = this.state.title,
    collection.detail = this.state.detail,
    collection.url = this.state.url,
    collection.mail = this.state.mail,
    collection.phone = this.state.phone,
    collection.category = this.state.category

    console.log('#HELLO:', collection);

    var url = 'my url';

    if(collection.title != '' ) {

            if(this.state.isNetConnected != false) {

              fetch(url, {
                method: 'POST',
                body: JSON.stringify(collection),
                headers: new Headers({
                  'Content-Type' : 'application/json',
                  'token': 'abcd',
                  'jwt': this.state.getValue

                })
              }).then(response =>
                {
                  this.setState({isLoading:false});
                  if (response.status !== 200) {
                      console.log('Status Code: ' + response.status);
                      return;
                  }

                  response.json().then(data =>{
                      console.log(data);
                      if(data.status == "saved") {
                        this.props.navigation.navigate('First'); 
                    }
                  });
              }
                )
              .catch(error=>{
                this.setState({isLoading:false})
                console.error('Error:', error)

              })

            } else{
              this.setState({isLoading:false});
              Alert.alert("Oops!! No Internet Connection Available");
            }

    } 

    else {
      this.setState({isLoading:false})
      Alert.alert('Please fill up the required field');
    }

  }

在提交函数中你可以看到下面这行初始化了前一个屏幕——

  if(data.status == "saved") {
                        this.props.navigation.navigate('First'); 
                    }

返回NoteMeHome(第一屏),但没有刷新数据。

所以,我需要一个解决方案来刷新这个 NoteMeHome 屏幕并通过 API 调用显示最新数据。

【问题讨论】:

    标签: javascript react-native


    【解决方案1】:

    您可以在调用 navigate 时将回调函数作为参数传递。

    代替:

    this.props.navigation.navigate('First');

    添加这个:

    this.props.navigation.navigate('First', {
          onGoBack: () => this.refresh(),
        });
    

    然后添加回调函数:

    refresh() {
      this.doSomething();
    }
    

    希望对你有帮助!

    【讨论】:

    • 好吧,我在第一个屏幕的 componentDidMount() 函数中执行 API 调用部分。那么是不是应该在回调函数中调用componentDidMount函数呢?
    • 你可以试试这个方法: import {NavigationEvents} from 'react-navigation';将组件添加到您的渲染中: console.log('我被触发')} /> 现在,尽管来自 goBack( ) 或导航。您可以在此 onDidFocus 方法中添加代码。
    • 非常感谢您的建议,我按照以下链接中给出的示例解决了它 - [link]reactnavigation.org/docs/en/function-after-focusing-screen.html
    猜你喜欢
    • 2021-06-06
    • 2018-12-25
    • 1970-01-01
    • 2020-07-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-06-15
    • 1970-01-01
    相关资源
    最近更新 更多