首頁 > web前端 > Vue.js > 主體

vue3中怎麼使用element-plus呼叫message

WBOY
發布: 2023-05-17 15:52:31
轉載
3110 人瀏覽過

    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 完全不同。混淆可能會發生,當您在setup()中與其他選項式API一起使用它時。

    因此,可以透過呼叫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'
    });
    登入後複製

    以上是vue3中怎麼使用element-plus呼叫message的詳細內容。更多資訊請關注PHP中文網其他相關文章!

    相關標籤:
    來源:yisu.com
    本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
    熱門教學
    更多>
    最新下載
    更多>
    網站特效
    網站源碼
    網站素材
    前端模板