vue-cli整合axios的几种方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue-cli整合axios的几种方法相关的知识,希望对你有一定的参考价值。

Vue这个框架现在在单页面应用方面非常受人欢迎。

基于vue-cli创建的项目怎么样才能更好地处理网络请求?

首选的应该就是axios

这次给刚接触vue的新手介绍一下axios在vue中如何使用

安装的话自己去官网看

一、不推荐的方法

//在要使用网络请求的组件中导入axios
import axios from ‘axios‘ 
export default {
  name: ‘HelloWorld‘,
  data () {
    return {
      params:{}
    }
  },
  methods: {
//在这里调用网络请求
    request(){
      axios.get(`url${this.params}`).then(result=>{
        console.log(result)
    })
    }
  }
}

这种方法比较麻瓜哪个文件要用就  import axios from ‘axios‘ ,但是太过繁琐,也不利于维护。

二、网络请求较少

//打开main.js全局导入axios

import Vue from ‘vue‘
import App from ‘./App‘
import router from ‘./router‘
import axios from ‘axios‘

//存在prototype中
Vue.prototype.$http = axios

//需要使用axios的其他组件调用时可以通过两种方法
//Vue.$http.get(`url${params}`)
//this.$http.get(`url${params}`)
//但是这样使用会出现一个问题,在单独的js文件中这样做调用不了$http,原因是没有Vue的实例。大多数情况下用这种方法就可以满足大部分需求了

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: ‘#app‘,
  router,
  template: ‘<App/>‘,
  components: { App }
})

三、推荐方法

用方法二已经可以满足大部分需求了,写的时候也比较爽,但是后期如果接口改变,还要一个个去查找修改,会显得很杂乱

这里推荐一种自己平时的做法

//新建一个JS命名为api
import axios from ‘axios‘ 
//在api中导入axios
let base = ‘/v1‘

//把整个项目的网络请求都写在这个文件中用export导出

export const getproduct = params => { return axios.get(`${base}/product/info/${params}`) }

//这样写方便管理整个项目的网络请求
//在我们要是用这个请求时比如说getproduct

import {
    getproduct
  }from ‘../api/api‘;
export default {
  name: ‘HelloWorld‘,
  data () {
    return {
      params:{}
    }
  },
  methods: {
    getProductList(){
      getproduct(this.params).then(result=>{
        console.log(result);
      })
    }
  }
}
//注意我们导出的时候用的是export 所以导入的时候必须带{}

 

完!

 

以上是关于vue-cli整合axios的几种方法的主要内容,如果未能解决你的问题,请参考以下文章

vue-cli3中引入图片的几种方式和注意事项

浅析XSS的几种测试方法

vue-cli3 axios解决跨域问题

Axios请求头中常见的几种Content-Type

a标签调用js的几种方法

a标签调用js的几种方法