从 ReactNative-DatePickerAndroid 获取选定的日期

IT技术 android reactjs react-native
2021-05-01 10:52:54

我正在关注ReactNative DatePickerAndroid Docs对于 DatePickerIOS,我们有onDateChange方法。

有没有类似的方法可以从 DatePickerAndroid 获取选定的日期?上面的文档没有提到任何获取选定日期的代码示例。

2个回答

您可以从给定的代码示例中获取 showPicker 方法中的选定日期:

showPicker = async (stateKey, options) => {
    try {
      var newState = {};
      const {action, year, month, day} = await DatePickerAndroid.open(options);
      if (action === DatePickerAndroid.dismissedAction) {
        newState[stateKey + 'Text'] = 'dismissed';
      } else {
        // <<<< Newly selected date >>>>
        var date = new Date(year, month, day);
        newState[stateKey + 'Text'] = date.toLocaleDateString();
        newState[stateKey + 'Date'] = date;
      }
      this.setState(newState);
    } catch ({code, message}) {
      console.warn(`Error in example '${stateKey}': `, message);
    }
  };
render() {
   return (
   <TouchableWithoutFeedback
    onPress={this.showPicker.bind(this, 'spinner', { date: this.state.presetDate })}>
     <View>
        <Text style={styles.text}>Date selector</Text>
     </View>
   </TouchableWithoutFeedback>
  )
}

正如我们在文档中看到的示例代码,创建一个异步函数,该函数将处理Promise数据,并使用 onPress 函数或 TexInput 与 onFocus 函数触发此函数到您的组件 Text。例子:

async _onMyDatePress(){
   try {
            const {action, year, month, day} = await DatePickerAndroid.open({           
                date: new Date()
            });

            if(action == DatePickerAndroid.dateSetAction){
                console.log(year + ' ' + month + ' ' + day);
            }

        } catch ({code, message}) {
            console.warn('Cannot open date picker', message);
        }   
}