Vue3之getCurrentInstance与ts如何结合使用
这篇文章主要介绍“Vue3之getCurrentInstance与ts如何结合使用”,在日常操作中,相信很多人在Vue3之getCurrentInstance与ts如何结合使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue3之getCurrentInstance与ts如何结合使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
getCurrentInstance与ts结合使用
vue3项目中,如果不用ts这样使用是没问题的
const { proxy } = getCurrentInstance()在ts中使用会报错:报错:...类型ponentInternalInstance | null”
我们在项目中一般会用到很多getCurrentInstance()方法,直接封装一下
创建useCurrentInstance.ts文件:
import { ponentInternalInstance, getCurrentInstance } from 'vue'
export default function useCurrentInstance() {
const { appContext } = getCurrentInstance() as ponentInternalInstance
const proxy = appContext.config.globalProperties
return {
proxy
}
}组件内使用:
<script lang="ts">
import { definponent } from "vue";
import useCurrentInstance from "@/utils/useCurrentInstance";
export default definponent({
setup() {
const { proxy } = useCurrentInstance();
console.log(proxy);
},
});
</script>vue3+ts使用getCurrentInstance报错
vue3中没有this + 各种api的方法
vue3提供的方法,创建类似于this的实例。
const instance = getCurrentInstance()
const a1= getCurrentInstance();
a1.$toast({type: 'error', text: '登录失败' });这种只适合本地调试,运行到线上就会报错,报错详情为:
类型ponentInternalInstance | null”上不存在属性“proxy”。ts(2339)
然后下面会报这个错误
Unsafe member access .$axios on an `any` value. eslint@typescript-eslint/no-unsafe-member-access
Unsafe call of an `any` typed value. eslint@typescript-eslint/no-unsafe-call
原因:
getCurrentInstance()的返回类型存在null所以在此处添加断言即可。
在proxy后面添加?来过滤null的结果,即:
const instance = getCurrentInstance()?.proxy
instance ?.$toast('请xxx!')到此,关于“Vue3之getCurrentInstance与ts如何结合使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注测速网www.inhv.cn网站,小编会继续努力为大家带来更多实用的文章!
液化气是什么气体
天然气的运输方式
天然气的作用有哪些
氢气有没有毒性
氨气的危害及如何预防
液化气罐着火怎么办
家庭天然气阀门每天都要关闭吗
怎么样利用液氮保藏菌种
燃气使用注意事项
天然气怎么开采出来的


