<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                ThinkChat2.0新版上線,更智能更精彩,支持會話、畫圖、視頻、閱讀、搜索等,送10W Token,即刻開啟你的AI之旅 廣告
                # 未控制組件 在多數情況下,我們建議使用[控制組件](https://facebook.github.io/react/docs/forms.html)來實現表單。在一個控制組件中,表單數據被一個 React 組件處理。另外就是未控制組件,表單數據被 DOM 自己處理。 要編寫一個未控制組件,你可以使用一個 ref 來從 DOM 獲得 表單值,而不是為每個狀態更新編寫一個事件處理程序。 例如,這個代碼在一個未控制組件中接受一個單獨的名字: ~~~ class NameForm extends React.Component { constructor(props) { super(props); this.handleSubmit = this.handleSubmit.bind(this); } handleSubmit(event) { alert('A name was submitted: ' + this.input.value); event.preventDefault(); } render() { return ( <form onSubmit={this.handleSubmit}> <label> Name: <input type="text" ref={(input) => this.input = input} /> </label> <input type="submit" value="Submit" /> </form> ); } } ~~~ 在 CodePen 中[打開查看](https://codepen.io/gaearon/pen/WooRWa?editors=0010)。 由于一個未控制組件在 DOM 中保留真實的源,所以當使用未控制組件有時很容易集成 React 和 非 React 的代碼。如果你想快速和粗略的實現,也可以用較少的代碼。否則,你應該總是使用一個控制組件。 If it's still not clear which type of component you should use for a particular situation, you might find this article on controlled versus uncontrolled inputs to be helpful. 如果仍然不清楚在某個特定方案你應該使用哪種類型的組件,可以在[這個文章中](http://goshakkk.name/controlled-vs-uncontrolled-inputs-react/)了解控制和不控制組件來獲得幫助。 ## 默認值 在 React 渲染生命周期中,表單元素中的 value 屬性將會覆蓋 DOM 中的 value。使用一個未控制組件,你常常希望 React 來指定初始值,但是交給后續的更新未控制組件。要處理這種情況,可以指定一個 defaultValue 屬性用來替代 value 。 ~~~ render() { return ( <form onSubmit={this.handleSubmit}> <label> Name: <input defaultValue="Bob" type="text" ref={(input) => this.input = input} /> </label> <input type="submit" value="Submit" /> </form> ); } ~~~ 同樣,`<input type="checkbox">` 和 `<input type="radio">` 也支持 defaultChecked,而 `<select>` 支持 defaultValue。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看