Vue3安装使用Mock.js--解决跨域
2023-12-13 21:10:24
首先使用axios发送请求到模拟服务器上,再将mock.js模拟服务器数据返回给客户端。打包工具使用的是vite。
1.安装
npm i axios -S
npm i mockjs --save-dev
npm i vite-plugin-mock --save-dev
2.在vite.config.js文件中配置vite-plugin-mock等消息
import { viteMockServe } from 'vite-plugin-mock'
plugins: [vue(),
viteMockServe({
supportTs:true,
logger: false,
mockPath: "./mock/" // 注意:此时的 mockPath 地址是真正安装的 mock 文件夹的地址;
})
]
3.在根目录下创建mock文件夹及index.js文件:
4.在index.js文件中进行配置:
import Mock from 'mockjs'
const listUser = function() {
const a = Mock.mock({
'list|1-20':[{
'userId|+1':0,
'userName|1':["张三",'李四',"鲍勃","丽丽","李阳","杨洋","王五","周星星","大仙","孤影"],
'role|1':["系统管理员","操作人员","销售","平台管理者","仓库管理员","部长"],
}]
})
return a;
}
export default [
{
url:'/hello',
method:'get',
response: () => {
return listUser;
}
}
]
5.在页面中需要发送请求获取数据时,使用axios发送请求:
1)在request.js文件中创建axios
import axios from 'axios'
const request = axios.create({
baseURL:"http://127.0.0.1:5173/",
})
export default request
2)在需要发送请求的页面编写一下内容:
import request from './utils/request';
request({
method: 'GET',
url: "/hello",
}).then((res) => {
console.log(res);
})
显示结果:
如果显示报错:Access to XMLHttpRequest at ‘http://localhost:5173’ from origin ‘http://127.0.0.1:5173’ has been blocked by CORS policy: No ‘Access-Control-Allow-Origin’ header is present on the requested resource.
说明使用mock.js时遇到了跨域,需要进行以下配置:
1.在vite.config.ts中进行数据代理:
export default defineConfig({
plugins: [
vue(),
viteMockServe({
supportTs:true,
logger:false,
mockPath:"./mock/"
})
],
server: {
proxy: {
'/api': {
target:'http://127.0.0.1:5173/',
changeOrigin:true,//支持跨域
rewrite:(path) => path.replace(/^\/api/,""),//重写路径,替换/api
}
}
},
})
2.在axios基地址中添加/api即可
import axios from 'axios'
const request = axios.create({
baseURL:"/api",
timeout:5000
})
export default request
文章来源:https://blog.csdn.net/weixin_52199120/article/details/134980123
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!