时间:2021-07-01 10:21:17 帮助过:132人阅读
在看了element组件的源码后发现,所有模态框其实实现方法都差不多,主要用到了vue在组件化上的双向绑定。代码:
<!--查看槽点对话框--> <template lang="html"> <transition name="el-fade-in-linear"> <p draggable="true" @drag="mouseDrag" @dragend="mouseDragend" :style="dialogStyle" class="g-dialog-wrapper" v-show="myVisible"> <p class="g-dialog-header"> <p class="left"> 模态框 </p> <p class="right"> <i class="g-times-icon fa fa-times" @click="myVisible=false" aria-hidden="true"></i> </p> </p> <p class="g-dialog-container"> </p> </p> </transition> </template> <script> export default { props: { visible: Boolean }, created() { }, data() { return { myVisible: this.visible, }, computed: {}, methods: { }, components: {}, watch: { myVisible: function (val) { this.$emit('update:visible', val) }, visible: function (val) { this.myVisible = val } } } </script> <style lang="css" scoped> </style>
上面代码主要的部分是watch里面的代码,实现监听数据变化,及时更新。所以在使用的时候就很方便了,在component注册组件之后:
<g-key-dialog :visible.sync="keyDialogVisible"></g-key-dialog>
注:这里必须使用sync,要不是无法双向绑定的
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
解决vue页面刷新或者后退参数丢失的问题
vue页面离开后执行函数的实例
vue轮播图插件vue-concise-slider的使用
以上就是vue中实现模态框(通用写法)的详细内容,更多请关注Gxl网其它相关文章!