Vue-axios

文章目录

  • Vue axios
    • #0 GitHub
    • #1 需求
    • #2 环境
      • #2.1 安装axios
      • 2.2 配置
    • #3 开始
      • #3.1 最简单的Demo
      • #3.1 POST请求
    • 在这里插入图片描述
    • #4 模块化处理
      • #4.1 axios.js
      • #4.2 api.js
      • #4.3 开始使用
    • 20190918225302-image.png

Vue axios

#0 GitHub

https://github.com/Coxhuang/vue-axios-demo

#1 需求

  • 点击一个按钮,前端向后端发送http请求数据,后端返回数据给前端

#2 环境

#2.1 安装axios

npm install --save axios vue-axios

2.2 配置

import axios from 'axios'
import VueAxios from 'vue-axios'
Vue.use(VueAxios,axios);
axios.defaults.baseURL = "http://127.0.0.1:8000/"; // 后端接口的地址 

#3 开始

#3.1 最简单的Demo

前端向后端发送一个get请求

  • HelloWorld.vue




  • 界面

Vue-axios_第1张图片


  • 后端

Vue-axios_第2张图片

本文使用的后端框架是Python的Django框架, 需要注意的是,后端接口需要配置跨域问题,如果不配置跨域,会出现以下情况:

Vue-axios_第3张图片

后端返回的请求状态码仍然是200, 但是前段就是拿不到数据

Django解决跨域如下:

  • settings.py
...

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'corsheaders.middleware.CorsMiddleware',  # 跨域,必须放在这个位置,不能放在'django.middleware.common.CommonMiddleware'后面 
    'django.middleware.common.CommonMiddleware',
    ...
]

...

CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_ALLOW_ALL = True
CORS_ORIGIN_WHITELIST = (
    '*',
)

CORS_ALLOW_METHODS = (
    'DELETE',
    'GET',
    'OPTIONS',
    'PATCH',
    'POST',
    'PUT',
    # 'VIEW',
)

CORS_ALLOW_HEADERS = (
    'XMLHttpRequest',
    'X_FILENAME',
    'accept-encoding',
    'authorization',
    'content-type',
    'dnt',
    'origin',
    'User-agent',
    'x-csrftoken',
    'x-requested-with',
    'token',
)
...

#3.1 POST请求

  • HelloWorld.vue




Vue-axios_第4张图片

#4 模块化处理

  • 将axios的相关配置放进一个文件
  • 将所有用的路由接口放进一个文件

#4.1 axios.js

新建 src/utils/axios.js

import axios from 'axios' // 导入node_modules里的axios 

axios.defaults.baseURL = "http://127.0.0.1:8000/"; // 后端接口 ip:port 

export default axios // 导出axios 

#4.2 api.js

新建 src/api/api.js和src/api/index.js

  • index.js
import api_all from './api'

export default {
    api_all
}
  • api.js
import axios from '@/utils/axios' // 导入axios 

const api_all = {
    // 获取所有用户列表
    get_user_list(token) {
        return axios({
            url: '/api/user/list-user/',
            method: 'GET',
            // data: {
            //     token: token
            // },
        })
    }
};

export default api_all // 导出 api_all 

#4.3 开始使用

  • main.js
...
import axios from "./api/"; // 导入axios 
Vue.prototype.$api = axios; // 挂载到原型链上, 在vue组件里面可以通过this拿到

// 使用统一化管理,将以下代码注释掉
// import axios from 'axios'
// import VueAxios from 'vue-axios'
// Vue.use(VueAxios,axios);
// axios.defaults.baseURL = "http://127.0.0.1:8000/";
...
  • HelloWorld.vue



...

Vue-axios_第5张图片

你可能感兴趣的:(Vue)