首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过单击按钮重置选择器

通过单击按钮重置选择器
EN

Stack Overflow用户
提问于 2021-01-25 00:14:34
回答 1查看 287关注 0票数 1

我创建了一个功能组件,我试图通过单击一个按钮来重置或取消选择一个选择器,我试图使用forceUpdate(),但它不起作用。

我正在使用一个名为react-native-picker-select的库

我的代码:

代码语言:javascript
复制
import React, {useState} from 'react';
import { Text, View, StyleSheet, TouchableOpacity} from 'react-native';
import RNPickerSelect from 'react-native-picker-select';

export default function App() {
  const clean = () => {
    //reset picker
  }

  return (
    <View>
      <RNPickerSelect
            onValueChange={(value) => console.log("value")}
            placeholder={{
              label: 'Select'
            }}
            useNativeAndroidPickerStyle={false}
            items={[
                { label: 'Option 1', value: '1' },
                { label: 'Option 2', value: '2' },
                { label: 'Option 3', value: '3' },
            ]}
          />
          <TouchableOpacity
              onPress={clean}>
              <Text>Clean</Text>
          </TouchableOpacity>
    </View>
  );
}

运行的代码:

https://snack.expo.io/@rubend151/reset-picker

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-25 00:52:32

通过处理onValueChange和设置value,可以使控件成为受控控件。

根据github issue的说法,将值设置为null应该会重置选择,但不幸的是,这似乎不起作用。我将占位符项的值设置为0,这样我们就可以正确地休息它。

代码语言:javascript
复制
export default function App() {
  const [value, setValue] = React.useState(0);
  const clean = () => {
    //reset picker
    setValue(0) // <-- reset by setting the placeholder value.
  }

  return (
    <View>
      <RNPickerSelect
            onValueChange={(value) => setValue(value)} // <-- set  state manually.
            placeholder={{
              label: 'Select',
              value: 0
            }}
            useNativeAndroidPickerStyle={false}
            items={[
                { label: 'Option 1', value: '1' },
                { label: 'Option 2', value: '2' },
                { label: 'Option 3', value: '3' },
            ]}
            value={value} // <-- use the value from state
          />
          <TouchableOpacity
              onPress={clean}>
              <Text>Clean</Text>
          </TouchableOpacity>
    </View>
  );
}

https://snack.expo.io/_SweQ21QA

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65872929

复制
相关文章

相似问题

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