如何设置其他函数内部的值的状态

时间:2019-07-20 04:29:59

标签: javascript json reactjs clarifai

我正在尝试创建一个使用Clarifai API来检测图片年龄的React应用。 我能够Console.Log检测到年龄,但是我想在我的网页上显示年龄。帮助我设置AgeDectect状态,以便可以在我的网页上使用

             //Value Displayed On Console
              //39

            //App.js Code That Console.Logs Age
              class App extends Component {
            constructor(){
             super();
             this.state = {
             input : '',
             imgURL : '',
             AgeDetect : ''
             }
            }

            onInputChange = (event) => {
              this.setState({input : event.target.value});
             }

            onClickEvent = () => {
              this.setState({imgURL : this.state.input})

              app.models.predict(Clarifai.DEMOGRAPHICS_MODEL ,
                                 this.state.input).then(
                      function(response) {
                           const A =response.outputs[0].data.regions[0].
                                  data.face.age_appearance.concepts[0].name
             //This Line of Code Displays Age on Console 
                                  console.log(A);
                                  this.setState({AgeDetect : A});
                             },
          //Having Problem SettingState ,this.state.AgeDetect isnt
                                                //doing anything
         render(){
                return (<AgeDetection AgeDetect={this.state.AgeDetect}/>
                      )
                   }
             //AgeDetection.js file      
      import React from 'react' ; 
      const AgeDetection = ({AgeDetect}) => {
      return(       
             <div>
              {AgeDetect}
             </div>
           );
         }
         export default AgeDetection;

1 个答案:

答案 0 :(得分:0)

对由值返回的数组进行排序,然后将第一个对象或整个数组设置为您的状态,然后可以非常轻松地在应用程序中使用它。在您的预测中使用箭头功能,然后阻止绑定到该类。

class App extends Component {
  constructor() {
    super();
    this.state = {
      input: '',
      imgURL: '',
      AgeDetect: ''
    };
  }
  onInputChange = event => {
    this.setState({ input: event.target.value });
  };

  onClickEvent = () => {
    this.setState({ imgURL: this.state.input });
    app.models.predict(Clarifai.DEMOGRAPHICS_MODEL, this.state.input).then(
      response => {
        const A =
          response.outputs[0].data.regions[0].data.face.age_appearance
            .concepts[0].name;

        this.setState({ AgeDetect: A });
      },
      function(err) {
        // there was an error
      }
    );
  };

  render() {
    console.log(this.state);
    return (
      <div className='App'>
        <Navigation />
        <Logo />
        <ImageLinkForm
          onInputChange={this.onInputChange}
          onClickEvent={this.onClickEvent}
        />
        <FaceRecognition imgURL={this.state.imgURL} />
        <AgeDetection AgeDetect={this.state.AgeDetect} />
      </div>
    );
  }
}

export default App;