Vue3里用element-plus调用message,如何实现长尾词提示?

2026-04-01 14:142阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计546个文字,预计阅读时间需要3分钟。

Vue3里用element-plus调用message,如何实现长尾词提示?

目录 + Vue3使用Element Plus调用Message

1.全局引入Element Plus后

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

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

4.在Composition API中最简单的方法是按需引入Vue和Element Plus

目录
  • 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

    Vue3里用element-plus调用message,如何实现长尾词提示?

    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' });

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持易盾网络。

    本文共计546个文字,预计阅读时间需要3分钟。

    Vue3里用element-plus调用message,如何实现长尾词提示?

    目录 + Vue3使用Element Plus调用Message

    1.全局引入Element Plus后

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

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

    4.在Composition API中最简单的方法是按需引入Vue和Element Plus

    目录
    • 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

      Vue3里用element-plus调用message,如何实现长尾词提示?

      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' });

      以上为个人经验,希望能给大家一个参考,也希望大家多多支持易盾网络。