Diff
checker
Testo
Testo
Immagini
Documenti
Excel
Cartelle
Legal
Enterprise
Applicazione per desktop
Prezzi
Accedi
Scarica Diffchecker Desktop
Confronta il testo
Trova la differenza tra due file di testo
Strumenti
Cronologia
Editor live
Comprimi invariate
Senza a capo
Layout
Diviso
Unificato
Livello di dettaglio
Intelligente
Parola
Carattere
Evidenziazione sintassi
Scegli sintassi
Ignora
Trasforma testo
Vai alla prima modifica
Modifica input
Diffchecker Desktop
Il modo più sicuro per usare Diffchecker. Ottieni l'app Diffchecker Desktop: i tuoi diff non lasciano mai il tuo computer!
Ottieni Desktop
useFieldArray sandbox diff
Creato
4 anni fa
Il diff non scade mai
Eliminare
Esporta
Condividere
Spiegare
2 rimozioni
Linee
Totale
Rimosso
Caratteri
Totale
Rimosso
Per continuare a utilizzare questa funzione, aggiorna a
Diff
checker
Pro
Visualizza prezzi
144 linee
Copia tutti
1 aggiunta
Linee
Totale
Aggiunto
Caratteri
Totale
Aggiunto
Per continuare a utilizzare questa funzione, aggiorna a
Diff
checker
Pro
Visualizza prezzi
144 linee
Copia tutti
import React from "react";
import React from "react";
Copia
Copiato
Copia
Copiato
import { useForm, useFieldArray, Controller
, useWatch
} from "react-hook-form";
import { useForm, useFieldArray, Controller
} from "react-hook-form";
import ReactDOM from "react-dom";
import ReactDOM from "react-dom";
import "./styles.css";
import "./styles.css";
let renderCount = 0;
let renderCount = 0;
function App() {
function App() {
Copia
Copiato
Copia
Copiato
const { register, control, handleSubmit, reset
, watch
} = useForm({
const { register, control, handleSubmit, reset
} = useForm({
defaultValues: {
defaultValues: {
test: [{ firstName: "Bill", lastName: "Luo" }]
test: [{ firstName: "Bill", lastName: "Luo" }]
}
}
});
});
const {
const {
fields,
fields,
append,
append,
prepend,
prepend,
remove,
remove,
swap,
swap,
move,
move,
insert,
insert,
replace
replace
} = useFieldArray({
} = useFieldArray({
control,
control,
name: "test"
name: "test"
});
});
const onSubmit = (data) => console.log("data", data);
const onSubmit = (data) => console.log("data", data);
// if you want to control your fields with watch
// if you want to control your fields with watch
// const watchResult = watch("test");
// const watchResult = watch("test");
// console.log(watchResult);
// console.log(watchResult);
// The following is useWatch example
// The following is useWatch example
// console.log(useWatch({ name: "test", control }));
// console.log(useWatch({ name: "test", control }));
renderCount++;
renderCount++;
return (
return (
<form onSubmit={handleSubmit(onSubmit)}>
<form onSubmit={handleSubmit(onSubmit)}>
<h1>Field Array </h1>
<h1>Field Array </h1>
<p>The following demo allow you to delete, append, prepend items</p>
<p>The following demo allow you to delete, append, prepend items</p>
<span className="counter">Render Count: {renderCount}</span>
<span className="counter">Render Count: {renderCount}</span>
<ul>
<ul>
{fields.map((item, index) => {
{fields.map((item, index) => {
return (
return (
Copia
Copiato
Copia
Copiato
<li key={item
.id}>
<li key={item
?
.id}>
<input {...register(`test.${index}.firstName`)} />
<input {...register(`test.${index}.firstName`)} />
<Controller
<Controller
render={({ field }) => <input {...field} />}
render={({ field }) => <input {...field} />}
name={`test.${index}.lastName`}
name={`test.${index}.lastName`}
control={control}
control={control}
/>
/>
<button type="button" onClick={() => remove(index)}>
<button type="button" onClick={() => remove(index)}>
Delete
Delete
</button>
</button>
</li>
</li>
);
);
})}
})}
</ul>
</ul>
<section>
<section>
<button
<button
type="button"
type="button"
onClick={() => {
onClick={() => {
append({ firstName: "appendBill", lastName: "appendLuo" });
append({ firstName: "appendBill", lastName: "appendLuo" });
}}
}}
>
>
append
append
</button>
</button>
<button
<button
type="button"
type="button"
onClick={() =>
onClick={() =>
prepend({
prepend({
firstName: "prependFirstName",
firstName: "prependFirstName",
lastName: "prependLastName"
lastName: "prependLastName"
})
})
}
}
>
>
prepend
prepend
</button>
</button>
<button
<button
type="button"
type="button"
onClick={() =>
onClick={() =>
insert(parseInt(2, 10), {
insert(parseInt(2, 10), {
firstName: "insertFirstName",
firstName: "insertFirstName",
lastName: "insertLastName"
lastName: "insertLastName"
})
})
}
}
>
>
insert at
insert at
</button>
</button>
<button type="button" onClick={() => swap(1, 2)}>
<button type="button" onClick={() => swap(1, 2)}>
swap
swap
</button>
</button>
<button type="button" onClick={() => move(1, 2)}>
<button type="button" onClick={() => move(1, 2)}>
move
move
</button>
</button>
<button
<button
type="button"
type="button"
onClick={() =>
onClick={() =>
replace([
replace([
{
{
firstName: "test1",
firstName: "test1",
lastName: "test1"
lastName: "test1"
},
},
{
{
firstName: "test2",
firstName: "test2",
lastName: "test2"
lastName: "test2"
}
}
])
])
}
}
>
>
replace
replace
</button>
</button>
<button type="button" onClick={() => remove(1)}>
<button type="button" onClick={() => remove(1)}>
remove at
remove at
</button>
</button>
<button
<button
type="button"
type="button"
onClick={() =>
onClick={() =>
reset({
reset({
test: [{ firstName: "Bill", lastName: "Luo" }]
test: [{ firstName: "Bill", lastName: "Luo" }]
})
})
}
}
>
>
reset
reset
</button>
</button>
</section>
</section>
<input type="submit" />
<input type="submit" />
</form>
</form>
);
);
}
}
const rootElement = document.getElementById("root");
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);
ReactDOM.render(<App />, rootElement);
Diff salvati
Testo originale
Apri file
import React from "react"; import { useForm, useFieldArray, Controller, useWatch } from "react-hook-form"; import ReactDOM from "react-dom"; import "./styles.css"; let renderCount = 0; function App() { const { register, control, handleSubmit, reset, watch } = useForm({ defaultValues: { test: [{ firstName: "Bill", lastName: "Luo" }] } }); const { fields, append, prepend, remove, swap, move, insert, replace } = useFieldArray({ control, name: "test" }); const onSubmit = (data) => console.log("data", data); // if you want to control your fields with watch // const watchResult = watch("test"); // console.log(watchResult); // The following is useWatch example // console.log(useWatch({ name: "test", control })); renderCount++; return ( <form onSubmit={handleSubmit(onSubmit)}> <h1>Field Array </h1> <p>The following demo allow you to delete, append, prepend items</p> <span className="counter">Render Count: {renderCount}</span> <ul> {fields.map((item, index) => { return ( <li key={item.id}> <input {...register(`test.${index}.firstName`)} /> <Controller render={({ field }) => <input {...field} />} name={`test.${index}.lastName`} control={control} /> <button type="button" onClick={() => remove(index)}> Delete </button> </li> ); })} </ul> <section> <button type="button" onClick={() => { append({ firstName: "appendBill", lastName: "appendLuo" }); }} > append </button> <button type="button" onClick={() => prepend({ firstName: "prependFirstName", lastName: "prependLastName" }) } > prepend </button> <button type="button" onClick={() => insert(parseInt(2, 10), { firstName: "insertFirstName", lastName: "insertLastName" }) } > insert at </button> <button type="button" onClick={() => swap(1, 2)}> swap </button> <button type="button" onClick={() => move(1, 2)}> move </button> <button type="button" onClick={() => replace([ { firstName: "test1", lastName: "test1" }, { firstName: "test2", lastName: "test2" } ]) } > replace </button> <button type="button" onClick={() => remove(1)}> remove at </button> <button type="button" onClick={() => reset({ test: [{ firstName: "Bill", lastName: "Luo" }] }) } > reset </button> </section> <input type="submit" /> </form> ); } const rootElement = document.getElementById("root"); ReactDOM.render(<App />, rootElement);
Testo modificato
Apri file
import React from "react"; import { useForm, useFieldArray, Controller } from "react-hook-form"; import ReactDOM from "react-dom"; import "./styles.css"; let renderCount = 0; function App() { const { register, control, handleSubmit, reset } = useForm({ defaultValues: { test: [{ firstName: "Bill", lastName: "Luo" }] } }); const { fields, append, prepend, remove, swap, move, insert, replace } = useFieldArray({ control, name: "test" }); const onSubmit = (data) => console.log("data", data); // if you want to control your fields with watch // const watchResult = watch("test"); // console.log(watchResult); // The following is useWatch example // console.log(useWatch({ name: "test", control })); renderCount++; return ( <form onSubmit={handleSubmit(onSubmit)}> <h1>Field Array </h1> <p>The following demo allow you to delete, append, prepend items</p> <span className="counter">Render Count: {renderCount}</span> <ul> {fields.map((item, index) => { return ( <li key={item?.id}> <input {...register(`test.${index}.firstName`)} /> <Controller render={({ field }) => <input {...field} />} name={`test.${index}.lastName`} control={control} /> <button type="button" onClick={() => remove(index)}> Delete </button> </li> ); })} </ul> <section> <button type="button" onClick={() => { append({ firstName: "appendBill", lastName: "appendLuo" }); }} > append </button> <button type="button" onClick={() => prepend({ firstName: "prependFirstName", lastName: "prependLastName" }) } > prepend </button> <button type="button" onClick={() => insert(parseInt(2, 10), { firstName: "insertFirstName", lastName: "insertLastName" }) } > insert at </button> <button type="button" onClick={() => swap(1, 2)}> swap </button> <button type="button" onClick={() => move(1, 2)}> move </button> <button type="button" onClick={() => replace([ { firstName: "test1", lastName: "test1" }, { firstName: "test2", lastName: "test2" } ]) } > replace </button> <button type="button" onClick={() => remove(1)}> remove at </button> <button type="button" onClick={() => reset({ test: [{ firstName: "Bill", lastName: "Luo" }] }) } > reset </button> </section> <input type="submit" /> </form> ); } const rootElement = document.getElementById("root"); ReactDOM.render(<App />, rootElement);
Trovare la differenza