vue3中怎么使用element-plus调用message
短信预约 -IT技能 免费直播动态提醒
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的详细内容,更多请关注编程网其它相关文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341