我使用vuetify.js并努力创造可以是跨应用可重用的组件。虽然它的工作非常好,但我不确定它是否是正确的方法。试图绑定道具V模型
我创建具有相同的菜单选项,所有的时间抽屉式导航组件,但它可以从UI元素被打开。
以下是代码。
// NavigationBar.vue
<template>
<v-navigation-drawer
temporary
v-model="drawerFlag"
light
overflow
fixed
>
<v-list>
<v-list-tile>
<v-list-tile-action @click.stop="toggleDrawer()">
<v-btn icon>
<v-icon>close</v-icon>
</v-btn>
</v-list-tile-action>
</v-list-tile>
</v-list>
<v-list class="pt-0">
<template v-for="item in items">
<v-list-tile :key="item.title" :to="item.link">
<v-list-tile-action>
<v-icon>{{ item.icon }}</v-icon>
</v-list-tile-action>
<v-list-tile-content>
<v-list-tile-title>{{ item.title }}</v-list-tile-title>
</v-list-tile-content>
</v-list-tile>
<v-divider></v-divider>
</template>
</v-list>
</v-navigation-drawer>
</template>
<script>
export default {
props: ['drawer'],
data() {
return {
items: [
{ title: 'Home', icon: 'home', link: '/home'},
{ title: 'History', icon: 'history', link: '/history' },
{ title: 'Wallet', icon: 'account_balance_wallet', link: '/wallet' },
{ title: 'My Profile', icon: 'person', link: '/profile' },
{ title: 'Settings', icon: 'settings', link: '/settings' },
{ title: 'About', icon: 'error', link: '/about' },
{ title: 'Logout', icon: 'power_settings_new', link: '/logout' },
]
};
},
computed: {
drawerFlag: {
get: function() {
return this.drawer
},
set: function() {
}
}
},
methods: {
toggleDrawer: function() {
this.$emit('emitToggleDrawer');
}
}
}
</script>
//Home.vue
<template>
<div class="full-screen">
<navigation-bar :drawer="drawer" v-on:emitToggleDrawer="toggleDrawer"></navigation-bar>
<v-btn icon class="mt-3 fixed-position" @click.stop="drawer = !drawer">
<v-icon>menu</v-icon>
</v-btn>
</div>
</template>
<script>
export default {
name: 'home',
data() {
return {
drawer: null
};
},
computed: {
user() {
return this.$store.getters.user;
}
},
methods: {
toggleDrawer: function() {
this.drawer = !this.drawer;
}
}
};
</script>
在上面的代码..
在父组件,我有按钮打开导航抽屉并且导航抽屉的状态保持在称为“抽屉”的父组件中。然后,我将“抽屉”作为子组件传递给一个子组件,并将一个从子组件触发事件的方法传递给名为“emitToggleDrawer”的父组件。
在子组件中,我使用vuetify.js导航抽屉这需要V型=“drawerFlag”,其中drawerFlag是计算属性。当我试图使用v-model =“抽屉”,即绑定到道具时,我得到一个错误。然后,我们可以通过单击导航抽屉内的元素来关闭导航抽屉。为了达到这个目的,我调用了一个组件的方法,它随后发出一个由父组件监听的事件。
为什么您将'抽屉'重新定义为'drawerFlag',因为它已经在Home.vue数据()中注册过,并且您将其作为组件提供给它,您不能直接作为'抽屉'来访问吗? –
问题出在子组件上,当我们尝试使用v-model =“drawer”时,它给出了一个错误,说“避免直接改变一个道具,因为只要父组件重新渲染,值就会被覆盖,而是使用数据或基于道具值的计算属性。正被突变的道具:“抽屉”“。 – Arpit
所以另一种方法是在NavigationBar.vue中可以在data()中定义drawerFlag也是rt? –