React Native Change State from Custom Component(来自自定义组件的 React Native Change State)
问题描述
我有自定义选择器组件,我想更新 selectedValue 和 onValueChange 事件的状态.如果我直接在渲染部分添加选择器,它工作正常,但由于代码重复,我决定将我的选择器转换为自定义组件.所以我这样做了:
I have custom picker component and i want to update states on selectedValue and onValueChange event. It works fine if i add picker directly in render section but due to duplication of code i decided to convert my pickers into custom component. So i did it like this:
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;
我像这样调用不同的组件:
I call on different component like this:
<CustomPicker pickerLabel={"Select User"} selectedVal={this.state.selectedUser} pickerStyle={styles.picker} pickerData={this.state.userList} onChangeVal={this.state.selectedUser} />
标签 + 数据很好地填充到选择器中,但事件出现了问题.它没有更新拾取数据的状态,我错过了什么?
Label + data is populating in picker nicely but issue is coming on events. Its not updating state on picking data, What am i missing?
推荐答案
您需要在父组件中创建一个函数来更改值,因为您正在尝试更改 state
在无状态组件
You need to make a function in the parent component to change the values, since you're trying to change the state
in a stateless component
相反,你需要做的是
父组件
onChange = (itemValue, itemIndex) => {
// Set the state here and update as required
}
<CustomPicker pickerLabel={"Select User"} selectedVal={this.state.selectedUser} pickerStyle={styles.picker} pickerData={this.state.userList} onChangeVal={this.onChange} />
子组件
onValueChange={onChangeVal}>
对于多个选择器:
父组件
state = {
user: [
{value: 'Something', key: 0, label: 'Select User', userList: [//...Some Array here]},
{value: 'Something Else', key: 1, label: 'Dont Select User', userList: [//...Some Array here]}
]
}
onChange = (itemValue, itemIndex, pickerIndex) => {
// Update the states based on the pickerIndex
}
const {user} = this.state
// Use a map here
user.map((data, index) => (
<CustomPicker key={index} index={index} pickerLabel={data.label} selectedVal={data.value} pickerStyle={styles.picker} pickerData={data.userList} onChangeVal={this.onChange} />
))
子组件
const {
index, <== Picker Index
pickerLabel,
selectedVal,
onChangeVal,
pickerStyle,
pickerData,
...attributes
} = props;
<Picker
selectedValue={selectedVal}
style={[pickerStyle]}
onValueChange={(itemValue, itemIndex) => this.props.onChangeVal(itemValue, itemIndex, index)}> <== Pass picker value to the parent
这篇关于来自自定义组件的 React Native Change State的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:来自自定义组件的 React Native Change State
基础教程推荐
- html表格如何通过更改悬停边框来突出显示列? 2022-01-01
- Vue 3 – <过渡>渲染不能动画的非元素根节点 2022-01-01
- 如何使用TypeScrip将固定承诺数组中的项设置为可选 2022-01-01
- 我可以在浏览器中与Babel一起使用ES模块,而不捆绑我的代码吗? 2022-01-01
- Chart.js 在线性图表上拖动点 2022-01-01
- 如何使用JIT在顺风css中使用布局变体? 2022-01-01
- Electron 将 Node.js 和 Chromium 上下文结合起来意味着 2022-01-01
- 直接将值设置为滑块 2022-01-01
- 用于 Twitter 小部件宽度的 HTML/CSS 2022-01-01
- 自定义 XMLHttpRequest.prototype.open 2022-01-01