我正在关注ReactNative DatePickerAndroid Docs。对于 DatePickerIOS,我们有onDateChange
方法。
有没有类似的方法可以从 DatePickerAndroid 获取选定的日期?上面的文档没有提到任何获取选定日期的代码示例。
我正在关注ReactNative DatePickerAndroid Docs。对于 DatePickerIOS,我们有onDateChange
方法。
有没有类似的方法可以从 DatePickerAndroid 获取选定的日期?上面的文档没有提到任何获取选定日期的代码示例。
您可以从给定的代码示例中获取 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);
}
}