在通信的時候容易出錯,或者信息根本傳不過來。那么這里就示例一下,怎么通過組件之間的通信完成點擊事件。
index.vue文件中:
<div> <el-button type="primary" @click="onShow">點我</el-button></div>
傳遞中介
<addForm :show="formShow" @onHide="formShow = false"></addForm>
引入組件,即是要彈出的組件
import addForm from './docsForm'export default {components: {addForm},data() {return {show: false,formShow: false}},watch: { show: { handler: function(newVal, oldVal) { this.show = newVal }, deep: true }},methods: {onShow() { this.formShow = true }}}該文件里面的方法就是這樣。
然后就是彈出組件docsForm.vue怎樣向上傳數據
<slidePanel :width="550" :show="show" title="添加知識" @changeShow="hide"><div class="docs-body"></div></slidePanel>export default {props: {show: false},methods: {hide() { this.$emit('onHide') },}在組件slidePanel.vue中
<template> <transition name="slide-panel-fade"> <div v-if="show" class="slide-panel" :style="{ width: width + 'px'}"> <div class="slide-panel-layout"> <div class="slide-panel-header"> <h3 class="slide-panel-header-title">{{title}}</h3> <button class="slide-panel-header-close" @click="onShow"><i class="el-icon-close"></i></button> </div> <div class="slide-panel-body"> <slot></slot> </div> </div> </div> </transition></template><script>export default { props: { title: String, show: Boolean, width: { type: Number, default: 500 } }, methods: { onShow() { this.$emit('changeShow', false) } }, watch: { show: { handler: function(newVal, oldVal) { this.show = newVal }, deep: true } }, mounted() { document.body.appendChild(this.$el) }, destroyed() { this.$el.remove() }}</script>這樣就可以實現不同組件之間的冊拉彈出。
以上所述是小編給大家介紹的使用vue實現點擊按鈕滑出面板的實現代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
新聞熱點
疑難解答