O singură sursă a adevărului în React
Pentru orice date care se modifică într-o aplicație React trebuie să existe o singură sursă a adevărului. Prin aceste cuvinte se înțelege că dacă aveți două stări și una dintre stări poate fi calculată pe baza celeilalte - înseamnă că una dintre stări este redundantă și trebuie eliminată.
Să discutăm despre acest lucru cu un exemplu. Să presupunem că aveți, de exemplu, două câmpuri de introducere: în primul se introduce temperatura în grade Fahrenheit, iar în al doilea - în grade Celsius. În același timp, dorim ca ambele câmpuri să fie sincronizate: atunci când se introduce temperatura într-un câmp, ea trebuie să se modifice corespunzător și în celălalt.
Abordarea greșită ar fi să folosiți două stări: una pentru temperatura în Fahrenheit, iar a doua - pentru Celsius. De ce este greșit: pentru că o temperatură se calculează din cealaltă, ceea ce înseamnă că ar trebui să existe o singură stare ca loc de stocare a datelor.
Scrieți implementarea sarcinii descrise.
Un anumit programator a scris cod care afișează suma elementelor unui array:
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); // suma elementelor array-ului nums
function handleChange(event) {
setValue(event.target.value);
}
function handleBlur(event) {
setNums([...nums, event.target.value]); // adăugăm un element în array
setSum(getSum([...nums, event.target.value])); // recalculăm suma
}
return <div>
<p>{sum}</p>
<input value={value} onChange={handleChange} onBlur={handleBlur} />
</div>;
}
Ce nu este în regulă cu acest cod? Corectați-l.
Un anumit programator a scris cod pentru editarea elementelor unui array:
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]); // scriem textul elementului editat într-o stare separată
}
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>;
}
Ce nu este în regulă cu acest cod? Corectați-l.