目标: 经过手风琴的小实例,了解vue的父子组件的事件传递方式(其中一种)。vue实例惟一标识_uid的实际使用。javascript
建议阅读时间: 3分钟css
手风琴,涉及到两个组件,<collapse>
和<collapse-item>
, 要实现的功能无非两点:html
<collapse-item>
的时候,父组件要知道点了谁小知识: 每一个Vue实例都会有一个递增的id,能够经过this._uid获取前端
代码实现:vue
// 引入vue
<script src="https://cdn.bootcss.com/vue/2.6.10/vue.min.js"></script>
// 定义个父组件collapse
Vue.component('Collapse', {
methods: {
cut(childId) {
this.$children.forEach(child => {
console.log('ci', child._uid)
if(child._uid !== childId) {
child.show = false;
}
});
}
},
template: `<div class="wrap"> <slot></slot> </div>`
})
复制代码
Vue.component('CollapseItem', {
props: ['title'],
data() {
return {show: false}
},
methods: {
change() {
console.log(this._uid)
this.$parent.cut(this._uid);
this.show = !this.show;
}
},
template: `<div> <div class="title" @click="change">{{title}}</div> <div v-show="show"> <slot></slot> </div> </div>`
})
复制代码
<div id="app">
<collapse>
<collapse-item title="react">内容1</collapse-item>
<collapse-item title="vue">内容2</collapse-item>
<collapse-item title="nodejs">内容2</collapse-item>
</collapse>
</div>
<script> let vm = new Vue({ el: '#app' }) </script>
复制代码
感谢阅读!java
我是海明月,前端小学生。node