最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - React Native TextInput setState() issue - Stack Overflow

programmeradmin0浏览0评论

I am having an issue with React Native's this.setState() within a TextInput's onChangeText. I am trying to display the content of the TextInput in the Text tag below it. However, it displays nothing -- the setState() call never changes this.state.searchtext. I also get no errors. Thank you in advance for your help! Here is my code:

 export default class ShowScreen extends Component {
constructor(props) {
    super(props);
    this.state = {
        searchtext: ""
    };
}
render() {
    var thisscreen = (
        <View>
            <ScrollView
                horizontal={true}
                showsHorizontalScrollIndicator={false}
                pagingEnabled={true}
            >
                <View
                    style={{
                        flex: 1,
                        height: totalheight,
                        justifyContent: "space-around",
                        alignItems: "center",
                        width: totalwidth,
                        backgroundColor: "#FF0000"
                    }}
                >
                    <TextInput
                        style={{ height: 80, fontSize: 20 }}
                        placeholder="placeholder"
                        value={this.state.searchtext}
                        onChangeText={searchtext =>
                            this.setState({ searchtext })
                        }
                        ref={input => {
                            this.textInput = input;
                        }}
                        returnKeyType="go"
                    />
                    <Text>{this.state.searchtext}</Text>
                </View>
            </ScrollView>
        </View>
    );
    return thisscreen;
}
}

I am having an issue with React Native's this.setState() within a TextInput's onChangeText. I am trying to display the content of the TextInput in the Text tag below it. However, it displays nothing -- the setState() call never changes this.state.searchtext. I also get no errors. Thank you in advance for your help! Here is my code:

 export default class ShowScreen extends Component {
constructor(props) {
    super(props);
    this.state = {
        searchtext: ""
    };
}
render() {
    var thisscreen = (
        <View>
            <ScrollView
                horizontal={true}
                showsHorizontalScrollIndicator={false}
                pagingEnabled={true}
            >
                <View
                    style={{
                        flex: 1,
                        height: totalheight,
                        justifyContent: "space-around",
                        alignItems: "center",
                        width: totalwidth,
                        backgroundColor: "#FF0000"
                    }}
                >
                    <TextInput
                        style={{ height: 80, fontSize: 20 }}
                        placeholder="placeholder"
                        value={this.state.searchtext}
                        onChangeText={searchtext =>
                            this.setState({ searchtext })
                        }
                        ref={input => {
                            this.textInput = input;
                        }}
                        returnKeyType="go"
                    />
                    <Text>{this.state.searchtext}</Text>
                </View>
            </ScrollView>
        </View>
    );
    return thisscreen;
}
}
Share Improve this question edited Sep 7, 2018 at 14:41 Mojtaba Moshfeghi far 5711 gold badge5 silver badges20 bronze badges asked Apr 2, 2018 at 6:42 HobbesHobbes 611 gold badge1 silver badge7 bronze badges 6
  • It will change this.state.searchtext .. You should give value props to TextInput. Like value={this.state.searchtext} – godsenal Commented Apr 2, 2018 at 6:44
  • @godsenal thank you for responding so quickly. Adding that prop just prevents me from entering anything into the TextInput. I want to be able to enter text into the TextInput, and have it be displayed in the Text tag below. – Hobbes Commented Apr 2, 2018 at 6:49
  • that's weird. Could you paste edited code? It might be typo error like misspelling this.state.searchtext – godsenal Commented Apr 2, 2018 at 6:53
  • @godsenal it says the ment is too long if I paste in all the code. However, the only line I added was this: value={this.state.searchtext} – Hobbes Commented Apr 2, 2018 at 6:54
  • I tested it, it works well.. Could you edit your question to current code? – godsenal Commented Apr 2, 2018 at 7:02
 |  Show 1 more ment

5 Answers 5

Reset to default 3

In your TextInput add value prop

<TextInput
 style={{height: 80, fontSize: 20}}
 placeholder="placeholder"
 value={this.state.searchtext}
 onChangeText={(searchtext) => this.setState({ searchtext })}
 ref={input => { this.textInput = input }}
 returnKeyType="go"
/>

Hey you have used a variable to store screen code which is thisscreen. This might be preventing it from updating state.

Your render function should be like this:

 render () {
   return (
     <View>
        <ScrollView
         horizontal={true}
         showsHorizontalScrollIndicator={false}
         pagingEnabled={true}
        >
             <View style={{
               flex: 1,
               height: totalheight,
               justifyContent: "space-around",
               alignItems: "center",
               width: totalwidth,
               backgroundColor: "#FF0000"
             }}>
             <TextInput
              style={{height: 80, fontSize: 20}}
              placeholder="placeholder"
              value={this.state.searchtext}
              onChangeText={(searchtext) => 
               this.setState({searchtext})}
              ref={input => { this.textInput = input }}
              returnKeyType="go"
             />
            <Text>{this.state.searchtext}</Text>
         </View>
      </ScrollView>
    </View>);
 }

onChangeText={(search_text) => this.setState({searchtext:search_text})}

try this, that might do job.

When you use setState, we provide a JSON as parameter. Please follow below code.

<TextInput
  style={{height: 80, fontSize: 20}}
  placeholder="placeholder"
  value={this.state.searchtext}
  onChangeText={(searchtext) => this.setState({ searchtext: searchtext })} // <-- 
  ref={input => { this.textInput = input }}
 returnKeyType="go"
/>

Do let me know if it does not work.

I think there might bug in React onChangeText method. You just need to replace onChangetText to onChange then It will work fine.

  <TextInput
            style={{height: 80, fontSize: 20}}
            placeholder="placeholder"
            onChange={(text) => this.setState({searchtext : text})}
            ref={input => { this.textInput = input }}
            returnKeyType="go"
          />
发布评论

评论列表(0)

  1. 暂无评论