我对VueJS州有点熟悉.
这是我的简单应用程序:
new Vue({
el: '#media-app',
data: {
activeTypes: [],
activeCategories: [],
medias: []
},
methods: {
getFilteredData: function () {
// some computing needed
// refresh vue
Vue.set(me, "medias", []);
},
filterMedia: function () {
console.debug(this.activeCategories);
console.debug(this.activeTypes);
this.getFilteredData();
}
}
});
还有一些HTML内容:
<input type="checkbox" id="i1" value="i1" class="filter categories" v-model="activeCategories" v-on:click="filterMedia()">
<label for='i1'>My cat 1</label>
</div>
@{{ activeCategories }}
当我选中复选框时,模板会正确地显示带有"i1"的@{{activeCategories}.但是控制台.debug(this.activeCategories)显示一个空array.我必须将调试放入更新的方法中,以获得正确的值.但如果我这样做,我就不能调用一个改变数据的方法,否则我会进入一个无限循环…
那么,我应该在哪里调用filterMedia函数才能从activeCategories访问更新的值呢?
谢谢你的帮助.