#環境:vue3 typescript element-plus
element已經在app.config.globalProperties 新增了全域方法$message
所以在options API中可以直接使用
mounted(){ (this as any).$message.success("this.$message"); }
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("聪明"); }) }
//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"); }) }
//helloworld.vue import { inject, defineComponent,onMounted } from 'vue'; import { ElMessage } from 'element-plus' export default = defineComponent{ setup(omprops,content){ onMounted(()=>{ ElMessage.success('按需引入'); }) }
在vue檔中使用
this.$message({ message: "提示信息", type: "success" })
在js檔中使用
ElementUI.Message({ message: '提示信息', type: 'warning' });
以上是vue3中怎麼使用element-plus呼叫message的詳細內容。更多資訊請關注PHP中文網其他相關文章!