最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • element-ui 弹窗组件封装

    正文概述 掘金(漓漾li)   2021-01-22   492

    封装el-dialog为一个组件

    我们在使用element-ui的时候,如果一个弹窗中的内容很多,那么我们经常会把这个弹窗封装成一个组件,如下:

    <!-- DetailDialog.vue html -->
    <template>
      <el-dialog  :visible.sync="visible" width="720px" >
        <p>弹窗内容</p>
      </el-dialog>
    </template>
    
    // DetailDialog.vue js
    <script>
      props: {
        visible: {
          type: Boolean,
          default: false
        }
      }
    </script>
    

    el-dialog会修改 props,并报错

    但是这样会有一个问题,当触发了el-dialog内部的关闭事件时, 比如点击弹窗阴影等, 它会emit事件来修改当前组件的props [visible],由于组件不能直接修改prop属性,然后就会报错。

    我们新增了一个中间变量innerVisible,来拦截props [visible]的修改和获取

    <!-- DetailDialog.vue html -->
    <template>
      <el-dialog  :visible.sync="innerVisible" width="720px" >
        <p>弹窗内容</p>
      </el-dialog>
    </template>
    
    // DetailDialog.vue js
    <script>
    export default {
      props: {
        visible: {
          type: Boolean,
          default: false
        }
      },
      computed: {
        innerVisible: {
          get: function() {
            return this.visible
          },
          set: function(val) {
            this.$emit('update:visible', val)
          }
        }
      }
    }
    </script>
    

    这样在el-dialog内部修改prop[visible]的时候,我们会通过emit('update:')的方式来通知父组件,避免直接修改props。当然父组件需要加上sync修饰符来接受修改:

    <!-- father.vue html -->
    <DetailDialog :visible.sync="detailVisible" />
    

    到此为止,封装的弹窗组件已经没有问题了。

    继续优化,使用v-model控制显示隐藏

    // DetailDialog.vue js
    <script>
    export default {
      model: {
        prop: 'visible',  // 修改 v-model 绑定的props名称
        event: 'toggle'  // 修改 v-model 绑定的自定义事件名
      },
      props: {
        visible: {
          type: Boolean,
          default: false
        }
      },
      computed: {
        innerVisible: {
          get: function() {
            return this.visible
          },
          set: function(val) {
            this.$emit('update:toggle', val)
          }
        }
      }
    }
    </script>
    

    接入了v-model,使用起来就更高大上而且整洁

    <!-- father.vue html -->
    <DetailDialog v-model="detailVisible" />
    

    继续优化,封装成mixins

    频繁封装弹窗组件时,那么上述逻辑也需要不停地复制,所以继续优化,把上述控制显示隐藏的逻辑封装成了mxins,直接复用即可

    // vModelDialog.js
    export default {
      model: {
        prop: 'visible',
        event: 'toggle'
      },
      props: {
        visible: {
          type: Boolean,
          default: () => {
            return false
          }
        }
      },
      computed: {
        innerVisible: {
          get: function() {
            return this.visible
          },
          set: function(val) {
            this.$emit('toggle', val)
          }
        }
      }
    }
    

    那么封装弹窗插件时,只需引入mixins即可完成显示隐藏逻辑。

    // DetailDialog.vue js
    <script>
    import vModelDialog from './vModelDialog.js'
    export default {
      mixins: [vModelDialog],
    }
    </script>
    

    起源地下载网 » element-ui 弹窗组件封装

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元