我有自定义选择器组件,我想更新 selectedValue 和 onValueChange 事件的状态。如果我直接在渲染部分添加选择器,它工作正常,但由于代码重复,我决定将我的选择器转换为自定义组件。所以我是这样做的:
import React, { Component } from 'react';
import {
StyleSheet,
View,
Modal,
ActivityIndicator
} from 'react-native';
import { Item, Picker } from 'native-base'
const CustomPicker = props => {
const {
pickerLabel,
selectedVal,
onChangeVal,
pickerStyle,
pickerData,
...attributes
} = props;
return (
<Picker
selectedValue={selectedVal}
style={[pickerStyle]}
onValueChange={(itemValue, itemIndex) => this.setState({onChangeVal: itemValue})}>
<Picker.Item label={pickerLabel} value={''}/>
{pickerData.map((item, key) => (
<Picker.Item label={item} value={item} key={key}/>)
)}
</Picker>
)
}
const styles = StyleSheet.create({
});
export default CustomPicker;
我像这样调用不同的组件:
<CustomPicker pickerLabel={"Select User"} selectedVal={this.state.selectedUser} pickerStyle={styles.picker} pickerData={this.state.userList} onChangeVal={this.state.selectedUser} />
标签 + 数据在选择器中很好地填充,但问题正在发生。它没有更新选择数据的状态,我错过了什么?