vue3中怎么使用element-plus调用message
时间:2023-05-18 02:26
环境:vue3+typescript+element-plus element已经在 app.config.globalProperties 添加了全局方法 $message 所以在options API中可以直接使用 props和context,context作为上下文取代this,但是context中只有emit,attrs,和slots,而直接在setup中使this,会出现问题:官方网站的说明: 在 setup() 内部,this 不会是该活跃实例的引用,因为 setup() 是在解析其它组件选项之前被调用的,所以 setup() 内部的 this 的行为与其它选项中的 this 完全不同。混淆可能会发生,当您在setup()中与其他选项式API一起使用它时。 因此,可以通过调用getCurrentInstance方法来获取实例。此方法在全局引入element-plus之后就可直接使用 在vue文件中使用 在js文件中使用 以上就是vue3中怎么使用element-plus调用message的详细内容,更多请关注Gxl网其它相关文章!vue3使用element-plus调用message
1. 全局引入element之后
mounted(){ (this as any).$message.success("this.$message"); }
2. 在Composition API中setup方法传入了两个变量
//helloworld.vueimport { getCurrentInstance, defineComponent,onMounted } from 'vue';export default = defineComponent{setup(omprops,content){ onMounted(()=>{ getCurrentInstance()?.appContext.config.globalProperties.$message.success("聪明"); })}
3. 还有一种方法是使用 provide/inject
//main.tsimport { 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.vueimport { inject, defineComponent,onMounted } from 'vue';export default = defineComponent{setup(omprops,content){ onMounted(()=>{ (inject('$message') as any).success("inject"); })}
4. 在Composition api中最简单的写法就是按需引入
//helloworld.vueimport { inject, defineComponent,onMounted } from 'vue';import { ElMessage } from 'element-plus'export default = defineComponent{setup(omprops,content){ onMounted(()=>{ ElMessage.success('按需引入'); })}
vue使用Element的message组件
this.$message({ message: "提示信息", type: "success"})
ElementUI.Message({ message: '提示信息', type: 'warning'});