下面是详细讲解“Vue如何将对象中所有的key赋为空值”的攻略:
一、使用Object.keys()和forEach或reduce
代码示例(使用forEach):
let obj = {name: "张三", age: 18, gender: "男"};
Object.keys(obj).forEach(key =>{
obj[key] = ""; // 或者写成 obj[key] = null;
});
console.log(obj); // 输出结果:{name: "", age: "", gender: ""}
代码示例(使用reduce):
let obj = {name: "张三", age: 18, gender: "男"};
Object.keys(obj).reduce((res, key) => {
res[key] = '';
return res;
}, obj);
console.log(obj); // 输出结果:{name: "", age: "", gender: ""}
二、使用Vue.set()方法
代码示例:
// Vue组件代码
data() {
return {
info: {name: "张三", age: 18, gender: "男"}
}
},
methods: {
clearObj() {
for (let key in this.info) {
Vue.set(this.info, key, ""); // 或者写成 Vue.set(this.info, key, null);
}
}
}
以上两种方法都可以将对象的所有key值赋为空字符串或null。如果只是想清空对象中的值,而不是置空key,可以使用Object.assign()方法或展开运算符进行赋值。