亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

REACT:翻譯組件 | 設置和訪問狀態

REACT:翻譯組件 | 設置和訪問狀態

料青山看我應如是 2022-06-16 14:40:54
我正在創建一個 REACT 組件,該組件通過基本上獲取用戶的輸入并使用簡單的鍵值對訪問翻譯來“翻譯”一個數字。除了我的 handleTranslate 方法外,一切正常。此方法的控制臺日志給我未定義。class MyComponent extends React.Component {  constructor(props) {    super(props);    this.state = {      input: '',      one: 'uno',      two: 'dos',      three: 'tres',      four: 'cuatro',      five: 'cinco',      six: 'seis',      seven: 'siete',      eight: 'ocho',      nine: 'nueve',      ten: 'diez',      answer: ''    };    this.handleChange = this.handleChange.bind(this);    this.handleTranslate = this.handleTranslate.bind(this);  };    handleChange(state) {    this.setState({      input: event.target.value    });  }  handleTranslate (state) {    var x = state.input;    this.setState({      answer: state.x    });  }    render () {  return(  <div>      <h3>Enter an English number between one and ten and watch the translation render below</h3>      <input value={this.state.value} onChange={this.handleChange, this.handleTranslate}/>      <p>{this.state.input}</p>  </div>  );  }};ReactDOM.render(<MyComponent/>, document.getElementById('view'));<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script><script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script><div id='view' />
查看完整描述

1 回答

?
有只小跳蛙

TA貢獻1824條經驗 獲得超8個贊

使用一個處理函數event就可以了


class App extends React.Component {

  constructor(props) {

    super(props);

    this.state = {

      input: "",

      one: "uno",

      two: "dos",

      three: "tres",

      four: "cuatro",

      five: "cinco",

      six: "seis",

      seven: "siete",

      eight: "ocho",

      nine: "nueve",

      ten: "diez",

      answer: ""

    };

    this.handleChange = this.handleChange.bind(this);

  }


  handleChange(event) {

    this.setState({

      input: event.target.value

    });

    this.setState({

      answer: this.state[event.target.value]

    });

  }

  render() {

    return (

      <div>

        <h3>

          Enter an English number between one and ten and watch the translation

          render below

        </h3>

        <input value={this.state.value} onChange={this.handleChange} />

        <p>{this.state.input}</p>

        <p>{this.state.answer}</p>

      </div>

    );

  }

}


ReactDOM.render(<App />, document.getElementById("root"));

<div id="root"></div>

<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.12.0/umd/react.production.min.js"></script>

<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.12.0/umd/react-dom.production.min.js"></script>



查看完整回答
反對 回復 2022-06-16
  • 1 回答
  • 0 關注
  • 159 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號