项目环境:nuxt+vue+axios
针对问题:如何在vue框架nuxt中使用axios模块
解决思路:
(1) 把nuxtjs-axios模块添加项目中
(2) 配置nuxt.config.js
(3) 简单使用
参考网址:http://www.axios-js.com/zh-cn/docs/nuxtjs-axios.html
注意事项:前台框架不同,使用的模块也有些不一样的。
例如:你没有使用nuxt框架,只使用vue,那么添加axios模块方式是:npm install --save axios vue-axios
具体步骤:
1. 把nuxtjs-axios模块添加到项目
yarn add @nuxtjs/axios // 使用yarn来安装模块
npm install @nuxtjs/axios // 使用npm来安装模块
注:不同的包管理器,要使用不同的命令
2. 配置nuxt.config.js
简单使用
modules: [
'@nuxtjs/axios'
],
如果这步完成,可以在项目中方法使用console.log(this) ,这时候可以看到该对象中有$axios属性了
如果你想使用代理可以这样写
modules: [
'@nuxtjs/axios'
],
axios: {
prefix: '/app', //在请求路径前,加上 /app
proxy: true
},
proxy: {
'/app': {
target: 'http://127.0.0.1:8080', //页面仍然显示 http://localhost:3000,但实际上是
//http://127.0.0.1:8080
pathRewrite: {'^/app': '/test'} //前面是一个正则表达式,后面是替换后的内容
}
},
当我们使用axios发送请求时
如果你使用axios发送请求且路径是/helo/hello,
那么会被axios中的prefix属性加上前缀,即/app/helo/helo
而proxy会使得请求变为,http://127.0.0.1:8080/app/helo/helo
而pathRewrite会把请求变为 http://127.0.0.1:8080/test/helo/helo
3.例子:
(1)页面中发送的请求时 /helo/helo
显示
(2)页面发送的请求 是/helo/helo ,实际上请求是http://localhost:8080/test/helo/helo,但页面只能看到的是
http://localhost:3000/app/helo/helo,
module.exports = {
mode: 'universal',
head: {
title: process.env.npm_package_name || '',
meta: [
{ charset: 'utf-8' },
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ hid: 'description', name: 'description', content: process.env.npm_package_description || '' }
],
link: [
{ rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' }
]
},
loading: { color: '#fff' },
css: [
],
plugins: [
],
modules: [
'@nuxtjs/axios',
],
axios: {
prefix: '/app', //在请求路径前,加上 /app
proxy: true
},
proxy: {
'/app': {
target: 'http://127.0.0.1:8080', //页面仍然显示 http://localhost:3000,但实际上是
//http://127.0.0.1:8080
pathRewrite: {'^/app': '/test'} //前面是一个正则表达式,后面是替换后的内容
}
},
build: {
extend(config, ctx) {
}
}
}
(3) showMsg方法能够处理的请求是,http://localhost:8080/test/helo/helo
package com.example.demo.controller;
import java.util.HashMap;
import java.util.Map;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
@RequestMapping("/test/helo")
public class HeloController {
@RequestMapping("/helo")
@ResponseBody
public String showMsg(String message) {
return message;
}
}