vue3中实现使用element-plus调用message

2022-10-14,,,

这篇文章主要介绍了vue3中实现使用element-plus调用message,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

目录
  • vue3使用element-plus调用message
    • 1. 全局引入element之后
    • 2. 在Composition API中setup方法传入了两个变量
    • 3. 还有一种方法是使用 provide/inject
    • 4. 在Composition api中最简单的写法就是按需引入
  • vue使用Element的message组件

    vue3使用element-plus调用message

    环境:vue3+typescript+element-plus

    1. 全局引入element之后

    element已经在 app.config.globalProperties 添加了全局方法 $message

    所以在options API中可以直接使用

      mounted(){
        (this as any).$message.success("this.$message");
      }

    2. 在Composition API中setup方法传入了两个变量

    props和context,context作为上下文取代this,但是context中只有emit,attrs,和slots,而直接在setup中使this,会出现问题:官方网站的说明:

    在 setup() 内部,this 不会是该活跃实例的引用,因为 setup() 是在解析其它组件选项之前被调用的,所以 setup() 内部的 this 的行为与其它选项中的 this 完全不同。这在和其它选项式 API 一起使用 setup() 时可能会导致混淆。

    所以可以使用getCurrentInstance方法获取实例。此方法在全局引入element-plus之后就可直接使用

    //helloworld.vue
    import { getCurrentInstance, defineComponent,onMounted } from 'vue';
    export default  = defineComponent{
    setup(omprops,content){
        onMounted(()=>{
          getCurrentInstance()?.appContext.config.globalProperties.$message.success("聪明");
        })
    }

    3. 还有一种方法是使用 provide/inject

    //main.ts
    import { createApp } from 'vue'
    import App from './App.vue'
    import element from 'element-plus'
    import 'element-plus/lib/theme-chalk/index.css'
    import {ElMessage} from 'element-plus'
    const app = createApp(App)
    app.use(element)
    //如果没有全局引用element,还需写下面一句
    //app.config.globalProperties.$message = ElMessage;
    app.provide('$message', ElMessage)
    app.mount('#app')
    //helloworld.vue
    import { inject, defineComponent,onMounted } from 'vue';
    export default  = defineComponent{
    setup(omprops,content){
        onMounted(()=>{
          (inject('$message') as any).success("inject");
        })
    }

    4. 在Composition api中最简单的写法就是按需引入

    //helloworld.vue
    import { inject, defineComponent,onMounted } from 'vue';
    import { ElMessage } from 'element-plus'
    export default  = defineComponent{
    setup(omprops,content){
        onMounted(()=>{
          ElMessage.success('按需引入');
        })
    }

    vue使用Element的message组件

    在vue文件中使用

    this.$message({
      message: "提示信息",
      type: "success"
    })

    在js文件中使用

    ElementUI.Message({
      message: '提示信息',
      type: 'warning'
    });

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持北冥有鱼。

    您可能感兴趣的文章:

    • element-plus按需引入后ElMessage与ElLoading在页面中的使用
    • Vue3实现Message消息组件示例
    • Vue3.x中使用element-plus的各种方式详解
    • vue3.0中使用element的完整步骤

    《vue3中实现使用element-plus调用message.doc》

    下载本文的Word格式文档,以方便收藏与打印。