码迷,mamicode.com
首页 > 移动开发 > 详细

vue-cli整合axios的几种方法

时间:2017-11-22 20:03:07      阅读:308      评论:0      收藏:0      [点我收藏+]

标签:维护   两种   const   component   config   res   nts   情况下   需求   

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的几种方法

标签:维护   两种   const   component   config   res   nts   情况下   需求   

原文地址:http://www.cnblogs.com/rinzoo/p/7880525.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!