Vue+Typescript中在Vue上挂载axios使用时报错怎么办
这篇文章将为大家详细讲解有关Vue+Typescript中在Vue上挂载axios使用时报错怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
在vue
项目开发过程中,为了方便在各个组件中调用axios
,我们通常会在入口文件将axios挂载到vue原型身上,如下:main.ts
import Vue from 'vue'
import axios from './utils/http'
Vue.prototype.$axios = axios;
这样的话,我们在各个组件中进行请求时,就可以直接使用this.$axios
,但是在ts中使用this.$axios
进行请求时,会进行报错,如下所示:
从图中我们可以看出ts在Vue身上检测不到$axios。通过
在网上查阅发现:在ts中,不识别vue下面挂$axios,不可以挂在原型链上。也就是说我们手动在Vue原型身上挂载$axios,ts无法识别到。
解决方法1:手动告诉ts忽略这里的类型检测
虽然ts无法检测到Vue原型身上的prototype
,但是实际上我们是挂载成功的,也就是说我们是可以正常使用的,唯一需要解决的是ts的类型检测问题,因此,我们可以指定this为any
类型,这样的话就可以避免报错问题。如下所示:
(this as any).$axios
.post("/api/users/login", this.ruleForm)
.then((res: {data:any}) => {}
但是使用any
意味着失去了类型安全保障,并且你得不到工具的支持。
解决方法2:使用vue-axios
这个包来处理这个挂载问题
我们可以通过使用vue-axios
这个包来处理这个挂载问题。vue-axios 是在axios基础上扩展的插件,在Vue.prototype原型上扩展了$http等属性,可以更加方便的使用axios。
# 安装
npmi axios
npm i vue-axios -S
# 注册
Vue.use(axios,vue-axios)
# 使用
this.axios()
通过使用vue-axios
包,我们可以直接使用this.axios
进行调用。
从上面我们可以看出vue-axios
帮助我们实现了在Vue
原型身上挂载axios
,而且能够被ts检测到。这样就完美避免了ts报错的问题。
关于“Vue+Typescript中在Vue上挂载axios使用时报错怎么办”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341