⊗jsrtPmFmsAIB 70 of 112 menu

การเชื่อมอินพุตกับอาร์เรย์ใน React

ให้ในสเตต notes มีการเก็บอาร์เรย์:

function App() { const [notes, setNotes] = useState([1, 2, 3]); return <div> </div>; }

ให้เรามีฟังก์ชันเสริมด้วย ซึ่งหาผลรวมขององค์ประกอบอาร์เรย์:

function getSum(arr) { let sum = 0; for (const elem of arr) { sum += +elem; } return sum; } function App() { ... }

มาดูกันและแสดงผลรวมขององค์ประกอบ อาร์เรย์จากสเตตของเรา โดยใช้ ฟังก์ชันเสริมของเรา:

function App() { const [notes, setNotes] = useState([1, 2, 3]); return <div> {getSum(notes)} </div>; }

มาทำให้มีสามอินพุตและใน value ของแต่ละอินพุต ใส่ค่าองค์ประกอบหนึ่งของอาร์เรย์:

function App() { const [notes, setNotes] = useState([1, 2, 3]); return <div> <input value={notes[0]} /> <input value={notes[1]} /> <input value={notes[2]} /> {getSum(notes)} </div>; }

ตอนนี้มาเพิ่มอีเวนต์ onChange ให้กับอินพุตของเรา โดยสร้าง ฟังก์ชันจัดการ อีเวนต์ทั่วไปเพียงฟังก์ชันเดียว:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { // ฟังก์ชันจัดการอีเวนต์ทั่วไป } return <div> <input value={notes[0]} onChange={event => changeHandler(0, event)} /> <input value={notes[1]} onChange={event => changeHandler(1, event)} /> <input value={notes[2]} onChange={event => changeHandler(2, event)} /> {getSum(notes)} </div>; }

อย่างที่คุณเห็น ฟังก์ชัน changeHandler รับพารามิเตอร์แรกเป็นหมายเลขขององค์ประกอบอาร์เรย์ ที่อินพุตนั้นกำลังแก้ไข

ด้วยหมายเลขนี้ เราสามารถแทนที่องค์ประกอบ อาร์เรย์ด้วยเนื้อหาของอินพุต

มาทำกัน:

function changeHandler(index, event) { setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]); }

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

มารวมโค้ดทั้งหมดของเราเข้าด้วยกัน:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]); } return <div> <input value={notes[0]} onChange={event => changeHandler(0, event)} /> <input value={notes[1]} onChange={event => changeHandler(1, event)} /> <input value={notes[2]} onChange={event => changeHandler(2, event)} /> {getSum(notes)} </div>; }

สามารถทำได้โดยให้ อินพุตถูกสร้างในลูป:

function App() { const [notes, setNotes] = useState([1, 2, 3]); function changeHandler(index, event) { setNotes([...notes.slice(0, index), event.target.value, ...notes.slice(index + 1)]); } const result = notes.map((note, index) => { return <input key={index} value={note} onChange={event => changeHandler(index, event)} />; }); return <div> {result} {getSum(notes)} </div>; }

ให้อาร์เรย์ต่อไปนี้:

[1, 2, 3, 4, 5, 6, 7, 8, 9]

แสดงค่าเฉลี่ยเลขคณิต ขององค์ประกอบอาร์เรย์นี้บนหน้าจอ ในลูป สร้าง อินพุตสำหรับแก้ไของค์ประกอบ

ไทย
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
เราใช้คุกกี้สำหรับการทำงานของเว็บไซต์ การวิเคราะห์ และการปรับเนื้อหาให้เหมาะสมส่วนบุคคล การประมวลผลข้อมูลเกิดขึ้นตาม นโยบายความเป็นส่วนตัว.
ยอมรับทั้งหมด ปรับแต่ง ปฏิเสธ