您现在的位置是:网站首页> 编程资料编程资料
vue3中实现使用element-plus调用message_vue.js_
2023-05-24
486人已围观
简介 vue3中实现使用element-plus调用message_vue.js_
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' });以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
您可能感兴趣的文章:
相关内容
- Vue3后台管理系统之创建和配置项目_vue.js_
- 深入了解Javascript的事件循环机制_javascript技巧_
- 详解Jest 如何支持异步及时间函数实现示例_JavaScript_
- VsCode工具开发vue项目必装插件清单(推荐!)_vue.js_
- vue中v-if和v-show使用区别源码分析_vue.js_
- vue eslint报错error "Component name "*****" should always be multi-word"解决_vue.js_
- axios二次封装的详细过程与跨域问题_vue.js_
- 在node中如何调用python脚本_node.js_
- nodejs读取本地mp3和mp4等媒体文件并播放的案例_node.js_
- vue2从数据变化到视图变化之diff算法图文详解_vue.js_
