首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用picker在映射Picker项时更改picker值?

如何使用picker在映射Picker项时更改picker值?
EN

Stack Overflow用户
提问于 2020-04-18 05:59:21
回答 1查看 194关注 0票数 0

我不能成功更改选择器的选取值。当我点击其他值时,它会正确地改变,0.2秒后,它会再次放置第一个值。我不知道为什么。

你能帮我个忙吗?

代码语言:javascript
复制
 const [espaceSelected, setEspaceSelected] = useState(null);

    useEffect(() => {
        getEspaces().then(data => {
            setEspaces(data);
            AsyncStorage.setItem('id_espace',espaces[0].id_espace);
            setEspaceSelected(espaces[2].name);
        })
    }, []);

...
return ( ...
  <Picker selectedValue={espaceSelected ? espaceSelected : null} onValueChange={(value) => { setEspaceSelected(value.name);}}>
                {espaces ? espaces.map(e => {
                    return (
                        <Picker.Item color="#7B65AE" label={e.name} value={e.id_espace} />);
                }) : null}
            </Picker>
);

提前感谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-18 06:30:18

Picker的呈现代码中,您将值设置为value={e.id_espace},然后尝试访问onValueChange中的value.name,但value只是id,而不是具有idname的对象。

例如,您可以通过在任何地方使用name而不将其与id或对象混合来修复它:

代码语言:javascript
复制
...onValueChange={(name) => { setEspaceSelected(name); }} ...
...
<Picker.Item color="#7B65AE" label={e.name} value={e.name} />
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61281415

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档