首頁 > 軟體

vue3中實現使用element-plus呼叫message

2022-09-06 18:02:31

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

以上為個人經驗,希望能給大家一個參考,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com