我在 Vue 中得到了过滤器。模板:<b-button v-if="filterFilled()" @click="clearFilter"> Clear</b-button>数据:data () { return { filter: { price_from: '', price_to: '', surface_from: '', surface_to: '', floor: '', type: '', structure: '', }, } },我检查的方法是过滤器脏了:filterFilled(){ return (this.filter.price_from || this.filter.price_to || this.filter.surface_to || this.filter.surface_from || this.filter.floor || this.filter.type || this.filter.structure) },这工作正常,但我的问题是,是否存在更好的方法来询问对象是否已填充道具?
2 回答
data:image/s3,"s3://crabby-images/40e78/40e78179a15c2009a71a4fd9573fa07d4cd4be8b" alt="?"
MMTTMM
TA贡献1869条经验 获得超4个赞
您可以使用以下方法检查是否this.filter至少有一个truthy值some
filterFilled() {
return Object.values(this.filter).some(v => v)
}
data:image/s3,"s3://crabby-images/7423b/7423bde85be83a88e78856c814d79847666a6209" alt="?"
幕布斯7119047
TA贡献1794条经验 获得超8个赞
对于检查组件中数据的方法,您通常应该更喜欢计算属性而不是方法,因为它们的性能更高,并且仅在其某些依赖项更改时才调用:
...
data () {
return {
filter: {
price_from: '',
price_to: '',
surface_from: '',
surface_to: '',
floor: '',
type: '',
structure: '',
},
}
},
computed: {
filterFilled() {
// as in @adiga answer, which is great
return Object.values(this.filter).some(v => v);
}
}
添加回答
举报
0/150
提交
取消