element-plus对话框组件dialog二次封装后emit事件与国际化问题

问题描述:

我们在使用vue3+element-plus搭建项目时,如果把dialog组件进行二次封装将会遇到emit事件执行报警告问题,并且如果运用了国际化插件vue-i18n也会遇到切换路由$t方法报错问题!

组件封装示例:

<el-dialog :title="title" top="10vh" :fullscreen="device=='mobile'?true:false" :model-value="showDialog">
    <el-scrollbar :max-height="device=='mobile'?'70vh':'55vh'">
      <slot name="form"></slot>
    </el-scrollbar>
    <template #footer>
      <span class="dialog-footer">
        <slot name="btn"></slot>
        <el-button v-if="showBtn.submit" type="primary" @click="$emit('submit')" size="small">{{$t("dialogcom.comfirm")}}</el-button>
        <el-button v-if="showBtn.cancle" @click="$emit('cancle')" size="small">{{$t("dialogcom.cancle")}}</el-button>
      </span>
    </template>
  </el-dialog>

原因分析:

1、上面的源码中的$emit事件在页面加载时就会报如下的警告:
在这里插入图片描述
解决方案:
如下,在js中需要声明需要发射的事件就ok了:

export default {
  name: "dialogcom",
  emits: ["submit", "cancle"],
}

2、上面源码中的$t()方法在切换路由时就会如下报错,无法正常切换语言:
在这里插入图片描述

解决方案:

//把上面的$t换成$root.$t即可解决此问题
<el-dialog :title="title" top="10vh" :fullscreen="device=='mobile'?true:false" :model-value="showDialog">
    <el-scrollbar :max-height="device=='mobile'?'70vh':'55vh'">
      <slot name="form"></slot>
    </el-scrollbar>
    <template #footer>
      <span class="dialog-footer">
        <slot name="btn"></slot>
        <el-button v-if="showBtn.submit" type="primary" @click="$emit('submit')" size="small">{{$root.$t("dialogcom.comfirm")}}</el-button>
        <el-button v-if="showBtn.cancle" @click="$emit('cancle')" size="small">{{$root.$t("dialogcom.cancle")}}</el-button>
      </span>
    </template>
  </el-dialog>

为什么会造成这两个问题呢,我们先来看下文档,如下在这里插入图片描述
在这里插入图片描述

我由此推断dialog的特殊性,所以在我们二次封装后dialog组件内部是独立的,需要在内部调用原型链的属性和方法就要调用$root下的属性方法,emit也需要主动声明发射事件!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张大娃笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值