我有一个Vue.js应用程序,我有几个组件,只是为了处理一些重复的任务.
我也是从AJAX请求中获取数据.
我想要输入的是,如果在Vue数据(treeData
和flatTreeData
)更新并采取措施后发生了事件,那么我可以执行任何其他操作吗?
var app = new Vue({ el: 'body', data: { treeData: {items: {}}, flatTreeData: [], }, }); $.getJSON('./paths.json').done(function(data) { // apply the file structure to the vue app demo.treeData = data; demo.flatTreeData = flattenTree(data); });
Jeff.. 11
您可以使用watch
Vue实例的属性将侦听器添加到变量更改:http://vuejs.org/api/#watch
watch: { 'treeData': function (val, oldVal) { console.log('new: %s, old: %s', val, oldVal) } }
如果你要成为watch
一个像这样的对象treeData
,你可能需要使用该deep
标志来观察整个对象树.
watch: { 'treeData': { handler:function (val, oldVal){ console.log('new: %s, old: %s', val, oldVal) }, deep: true } }
Bill Criswel.. 8
我会computed
在这里使用房产.
你可以做:
{ data: { treeData: {} }, computed: { flatTreeData: function () { return flattenTree(this.treeData); } } }
现在这种方式每次更新treeData
时flatTreeData
都会更新.
您可以使用watch
Vue实例的属性将侦听器添加到变量更改:http://vuejs.org/api/#watch
watch: { 'treeData': function (val, oldVal) { console.log('new: %s, old: %s', val, oldVal) } }
如果你要成为watch
一个像这样的对象treeData
,你可能需要使用该deep
标志来观察整个对象树.
watch: { 'treeData': { handler:function (val, oldVal){ console.log('new: %s, old: %s', val, oldVal) }, deep: true } }
我会computed
在这里使用房产.
你可以做:
{ data: { treeData: {} }, computed: { flatTreeData: function () { return flattenTree(this.treeData); } } }
现在这种方式每次更新treeData
时flatTreeData
都会更新.