⊗jsrtPmCoTOS 96 of 112 menu

หลักการแหล่งความจริงเดียวใน React

สำหรับข้อมูลใดๆ ที่สามารถเปลี่ยนแปลงได้ในแอปพลิเคชัน React ต้องมีแหล่งความจริงเพียงแหล่งเดียว ความหมายของคำนี้คือ หากคุณมี state สองตัว และ state หนึ่งสามารถ คำนวณได้จากอีก state หนึ่ง นั่นหมายความว่า state หนึ่งในนั้นเป็น state ที่ไม่จำเป็นและต้องนำออก

เรามาพูดถึงเรื่องนี้ด้วยตัวอย่าง สมมติว่าคุณมี input สองช่อง: ในช่องแรกป้อนค่า อุณหภูมิเป็นองศาฟาเรนไฮต์ และในช่องที่สอง - เป็นองศาเซลเซียส และเราต้องการให้ input ทั้งสองช่องประสานกัน: เมื่อ ป้อนอุณหภูมิใน input หนึ่ง ค่านั้นควรจะ เปลี่ยนใน input อีกช่องตามความสัมพันธ์ที่กำหนด

วิธีการที่ผิดคือการสร้าง state สองตัว: หนึ่งสำหรับอุณหภูมิฟาเรนไฮต์ และอีกตัว - สำหรับเซลเซียส ทำไมถึงผิด: เพราะ อุณหภูมิหนึ่งคำนวณมาจากอีกอุณหภูมิหนึ่ง ซึ่งหมายความว่าสถานที่เก็บข้อมูล ควรเป็น state เดียวเท่านั้น

เขียนการใช้งานตามโจทย์ที่อธิบายไว้

โปรแกรมเมอร์คนหนึ่งเขียนโค้ดเพื่อแสดง ผลรวมขององค์ประกอบในอาร์เรย์:

function getSum(arr) { let res = 0; for (let elem of arr) { res += +elem; } return res; } function Calculator() { const [value, setValue] = useState(''); const [nums, setNums] = useState([1, 2, 3]); const [sum, setSum] = useState(6); // ผลรวมขององค์ประกอบในอาร์เรย์ nums function handleChange(event) { setValue(event.target.value); } function handleBlur(event) { setNums([...nums, event.target.value]); // เพิ่มองค์ประกอบเข้าไปในอาร์เรย์ setSum(getSum([...nums, event.target.value])); // คำนวณผลรวมใหม่ } return <div> <p>{sum}</p> <input value={value} onChange={handleChange} onBlur={handleBlur} /> </div>; }

โค้ดนี้มีปัญหาอะไร? กรุณาแก้ไข

โปรแกรมเมอร์คนหนึ่งเขียนโค้ดสำหรับแก้ไข องค์ประกอบในอาร์เรย์:

function App() { const [notes, setNotes] = useState([1, 2, 3, 4, 5]); const [editNum, setEditNum] = useState(null); const [value, setValue] = useState(''); const result = notes.map((note, index) => { return <p key={index} onClick={() => startEdit(index)}> {note} </p>; }); function startEdit(index) { setEditNum(index); setValue(notes[index]); // เขียนข้อความขององค์ประกอบที่กำลังแก้ไขไปยัง state แยก } function changeItem(event) { setValue(event.target.value); setNotes([...notes.slice(0, editNum), event.target.value,...notes.slice(editNum + 1)]); } return <div> {result} <input value={value} onChange={changeItem} /> </div>; }

โค้ดนี้มีปัญหาอะไร? กรุณาแก้ไข

ไทย
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣTürkmenTürkçeЎзбекOʻzbekTiếng Việt
เราใช้คุกกี้สำหรับการทำงานของเว็บไซต์ การวิเคราะห์ และการปรับเนื้อหาให้เหมาะสมส่วนบุคคล การประมวลผลข้อมูลเกิดขึ้นตาม นโยบายความเป็นส่วนตัว.
ยอมรับทั้งหมด ปรับแต่ง ปฏิเสธ