React
प्रतिक्रिया स्वरूप
खोज…
नियंत्रित घटक
एक नियंत्रित घटक एक मूल्य के लिए बाध्य है और इसके परिवर्तन ईवेंट आधारित कॉलबैक का उपयोग करके कोड में संभाले जाते हैं।
class CustomForm extends React.Component {
constructor() {
super();
this.state = {
person: {
firstName: '',
lastName: ''
}
}
}
handleChange(event) {
let person = this.state.person;
person[event.target.name] = event.target.value;
this.setState({person});
}
render() {
return (
<form>
<input
type="text"
name="firstName"
value={this.state.firstName}
onChange={this.handleChange.bind(this)} />
<input
type="text"
name="lastName"
value={this.state.lastName}
onChange={this.handleChange.bind(this)} />
</form>
)
}
}
इस उदाहरण में हम एक खाली व्यक्ति ऑब्जेक्ट के साथ राज्य को इनिशियलाइज़ करते हैं। हम फिर व्यक्ति वस्तु के अलग-अलग कुंजी के लिए 2 आदानों के मूल्यों को बांधते हैं। तब उपयोगकर्ता प्रकारों के रूप में, हम प्रत्येक मान को handleChange फ़ंक्शन में handleChange करते हैं। चूंकि घटकों के मूल्य राज्य के लिए बाध्य हैं, इसलिए हम setState() कॉल करके उपयोगकर्ता प्रकारों के रूप में setState() कर सकते हैं।
नोट: नियंत्रित घटकों के साथ काम करते समय setState() कॉल नहीं करना, उपयोगकर्ता को टाइप करने का कारण होगा, लेकिन इनपुट नहीं देखें क्योंकि रिएक्ट केवल तब बदलता है जब ऐसा करने के लिए कहा जाता है।
यह भी ध्यान रखना महत्वपूर्ण है कि इनपुट के नाम व्यक्ति वस्तु में कुंजियों के नाम के समान हैं। यह हमें शब्दकोश रूप में मूल्य को पकड़ने की अनुमति देता है जैसा कि यहां देखा गया है।
handleChange(event) {
let person = this.state.person;
person[event.target.name] = event.target.value;
this.setState({person});
}
person[event.target.name] एक ही person[event.target.name] है person.firstName || person.lastName । बेशक यह इस बात पर निर्भर करेगा कि वर्तमान में कौन सा इनपुट टाइप किया जा रहा है। चूंकि हम नहीं जानते हैं कि उपयोगकर्ता कहाँ टाइप करेगा, एक शब्दकोश का उपयोग करके और इनपुट नामों को कुंजी के नामों से मिलाते हुए, हमें उपयोगकर्ता इनपुट नं। मामला जहां onChange से बुलाया जा रहा है।