我的onChange
用于提交具有多个输入值的表单的处理程序,并接受给定输入字段的名称属性。所以我基本上知道这段代码的作用,但我不知道到底发生了什么。
为什么 [e.target.name]
中的括号?
我也知道在这种情况下setFormData({ ...formData, name: e.target.value});
该函数每次都会用属性名称更改输入字段的值。
const Register = ({ setAlert, register, isAuthenticated }) => {
const [formData, setFormData] = useState({
name:"",
email:"",
password: "",
password2: ""
});
const {name, email, password, password2} = formData;
const onChange = e =>
setFormData({ ...formData, [e.target.name]: e.target.value});
如果有人知道就好了。
最佳答案
spread operator : ... 用于获取数组或对象的所有属性(当然还有值)
const arr = ["a", "b","c"]; const arr2 = [...arr, "d"]; // arr2 -> ["a", "b","c", "d"]
backets 用于将变量值作为属性
const prop = "myProp"; const obj = {[prop] : "value"} // obj -> {myProp : value}
关于javascript - 为什么这个函数 setFormData({ ...formData, [e.target.name] : e. target.value}); 中包含这些括号?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64105922/