Heim >Web-Frontend >js-Tutorial >Detaillierte Erläuterung der Verwendung von Formularen in React
Dieses Mal werde ich Ihnen die Verwendung von Formularen in React ausführlich erklären. Was sind die Vorsichtsmaßnahmen bei der Verwendung von Formularen in React? Hier sind praktische Fälle.
React ist ein unidirektionales Datenfluss-Framework, daher unterscheiden sich die Formularelemente von anderen DOM-Elementen und auch die Bedienung unterscheidet sich stark vom bidirektionalen Bindungs-Framework. Deshalb werde ich hier separat darüber sprechen.
import React from 'react' import ReactDOM from 'react-dom' class Component1 extends React.Component{ constructor(props){ super(props) this.state = { text: 'Hello React' } } render(){ return ( <p> <p><label>写死value-锁定状态</label><input type="text" value="hello react"/></p> <p><label>动态value-锁定状态</label><input type="text" value={this.state.text}/></p> <p><label>不指定value-没锁状态</label><input type="text"/></p> </p> ) } } ReactDOM.render(<Component1 />, document.getElementById('p1'));
Dieser Fall zeigt, dass in React das Formularelement nach der Wertangabe aufgrund des unidirektionalen Datenflusses nicht erneut geändert werden kann und daher mit <a href="http://www.php.cn/wiki/1464.html" target="_blank">onChange<code><a href="http://www.php.cn/wiki/1464.html" target="_blank">onChange</a>
-Ereignis muss abgeschlossen werden. Der obige Fall sollte also so aussehen:
class Component1 extends React.Component{ constructor(props){ super(props) this.state = { text: 'Hello React' } } change = (e) => { this.setState({text: e.target.value}) } render(){ return ( <p> <p><label>写死value-锁定状态</label><input type="text" value="hello react" onChange={this.change}/></p> <p><label>动态value-没锁状态</label><input type="text" value={this.state.text} onChange={this.change}/></p> <p><label>不指定value-没锁状态</label><input type="text"/></p> </p> ) } }
Effektvorschau
In gewöhnlichem HTML ist das textarea
-Element der Knotentextwert
<textarea> Hello there, this is some text in a text area </textarea>
Aber in React muss dieses Element das Attribut value
verwenden.
class Component1 extends React.Component{ constructor(props){ super(props) this.state = { text: 'Hello React' } } change = (e) => { this.setState({text: e.target.value}) } render(){ return ( <p> <textarea value={this.state.text} onChange={this.change}/> </p> ) } }
Um in gewöhnlichem HTML den standardmäßig ausgewählten Wert für das Element select
anzugeben, müssen Sie das Attribut option
selected
<select> <option value="grapefruit">Grapefruit</option> <option value="lime">Lime</option> <option selected value="coconut">Coconut</option> <option value="mango">Mango</option> </select>🎜>Aber in React müssen Sie nur das Attribut
class Component1 extends React.Component{ constructor(props){ super(props) this.state = { text: 'lime' } } change = (e) => { this.setState({text: e.target.value}) } render(){ return ( <p> <select value={this.state.text} onChange={this.change}> <option value="grapefruit">Grapefruit</option> <option value="lime">Lime</option> <option value="coconut">Coconut</option> <option value="mango">Mango</option> </select> </p> ) } }
value
Eingabedateielement angeben für die spezielle Verarbeitung verwendet werden <input type="file">
class Component1 extends React.Component{ submit = (e) => { console.log(this.file.files) } render(){ return ( <p> <input type='file' ref={input => {this.file = input}}/> <input type="button" value="submit" onClick={this.submit} /> </p> ) } }
ref
Ich glaube, dass Sie die Methode beherrschen, nachdem Sie den Fall in diesem Artikel gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln zu PHP Chinesische Website! Empfohlene Lektüre:
Detaillierte Erläuterung der Schritte zur Auswahl der Li-Hervorhebung in ReactJSON- und Mathe-Anwendungsfallanalyse in JSDas obige ist der detaillierte Inhalt vonDetaillierte Erläuterung der Verwendung von Formularen in React. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!