vue3中實現使用element-plus調用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' });
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- 詳解vue element plus多語言切換
- vue3集成Element-plus實現按需自動引入組件的方法總結
- 一篇文章告訴你如何編寫Vue插件
- Vue前端整合Element Ui的教程詳解
- Vue 中 provide和inject的使用