การเชื่อมอินพุตกับอาร์เรย์ใน 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]
แสดงค่าเฉลี่ยเลขคณิต ขององค์ประกอบอาร์เรย์นี้บนหน้าจอ ในลูป สร้าง อินพุตสำหรับแก้ไของค์ประกอบ