【 错误总结 】axios请求本地 Json

这篇博客介绍了如何在Vue项目中配置mock文件夹,用于存放模拟数据,并通过vue.config.js设置devServer的before方法,响应不同API请求,返回对应的JSON数据。同时展示了在Vue组件中使用$axios获取这些模拟数据的方法。

结构目录

在这里插入图片描述
将模拟的数据存储在mock文件夹下 配置vue.config.js

const login = require('./src/mock/login.json')
const sort = require('./src/mock/sort.json')
const city = require('./src/mock/city.json')
const classify = require('./src/mock/classify.json')
const shop = require('./src/mock/shop.json')
const address = require('./src/mock/address.json')
const merchant = require('./src/mock/merchant.json')
const grade = require('./src/mock/grade.json')
module.exports = {
    devServer: {
        before: (app) => {
            app.get('/login', function (req, res, next) {
                res.json(login)
            })
            app.get('/sort', function (req, res, next) {
                res.json(sort)
            })
            app.get('/city', function (req, res, next) {
                res.json(city)
            })
            app.get('/classify', function (req, res, next) {
                res.json(classify)
            })
            app.get('/shop', function (req, res, next) {
                res.json(shop)
            })
            app.get('/address', function (req, res, next) {
                res.json(address)
            })
            app.get('/merchant', function (req, res, next) {
                res.json(merchant)
            })
            app.get('/grade', function (req, res, next) {
                res.json(grade)
            })
        }
    },
    // 关闭eslint检查
    lintOnSave: false,
};

请求数据

new Vue({
	methods:{
		getData() {
      		this.$axios({
	        url: "sort",
	        method: "get",
	        contentType: "application/json",
	        dataType: "jsonp",
	    })
	       .then((data) => {
	       		this.filterData = data.data;
	       })
	       .catch((error) => error);
    },
	}
})
<think>我们有两个问题需要解决:1.解决Can'tresolve'axios'错误2.如何使用axios读取本地JSON文件首先,针对第一个问题:Can'tresolve'axios'根据之前的总结,这个错误通常是因为有安装axios依赖,或者安装有问题,或者引入方式不对。步骤:1.确保已经安装了axios。在项目根目录下运行:npminstallaxios或者yarnaddaxios2.安装后,检查package.json文件中是否有axios的依赖项。3.在代码中正确引入axios:importaxiosfrom'axios';4.如果安装过程中出现依赖冲突,可以尝试:npminstall--legacy-peer-deps5.如果之前安装失败,可以删除node_modules文件夹和package-lock.json(或yarn.lock)后重新安装。6.确保在需要使用axios的文件中正确导入。第二个问题:如何使用axios读取本地JSON文件在Vue项目中(使用vue-cli3及以上版本),静态文件应该放在public目录下(老版本是static目录)。例如,将JSON文件放在public/data.json,或者为了更好的组织,可以放在public/static/data.json。然后,我们可以通过axios请求这个文件。注意,在开发环境中,public目录下的文件会被作为静态文件提供服务,因此可以直接通过根路径访问。例如,文件放在public/data.json,则请求的URL可以是'/data.json'。如果放在public/static/data.json,则请求的URL是'/static/data.json'。示例代码:1.封装axios实例(可选,但推荐):创建一个request.js文件(比如在src/utils/目录下):```javascriptimportaxiosfrom'axios';//创建axios实例constservice=axios.create({baseURL:'',//可以设置为空,因为请求的是当前域下的资源timeout:5000//超时时间});//请求拦截器(根据需要添加)service.interceptors.request.use(config=>{//在发送请求之前做些什么,例如添加token等returnconfig;},error=>{//对请求错误做些什么returnPromise.reject(error);});//响应拦截器service.interceptors.response.use(response=>{//对响应数据做点什么,例如只返回数据部分returnresponse.data;},error=>{//对响应错误做点什么returnPromise.reject(error);});exportdefaultservice;```2.在需要请求JSON文件的组件或模块中:```javascriptimportrequestfrom'@/utils/request';//根据你的路径调整//请求JSON数据request.get('/static/data.json').then(data=>{console.log(data);}).catch(error=>{console.error(error);});```注意:在public目录下的文件不会经过webpack处理,而是直接复制到输出目录(dist)。因此,如果你在构建后需要修改这些文件,可以直接在输出目录中修改。另外,如果在开发过程中遇到404错误,请确保:-JSON文件确实放在public目录(或public的子目录)中。-请求的URL路径与文件在public目录下的路径一致(注意大小写)。如果之前有配置过webpack的CopyWebpackPlugin(如引用[4]提到),在vue-cli3中通常不需要手动配置,因为public目录默认会被复制。但如果你修改了默认配置,可能需要检查。最后,如果解决了上述问题,应该可以成功请求。总结步骤:1.安装axios(解决Can'tresolve'axios'错误)2.JSON文件放入public目录(或子目录)3.使用axios发送GET请求,路径为`/文件名`(或子目录路径)如果按照以上步骤仍然遇到问题,请检查控制台是否有404错误,确保文件路径正确。下面我们给出一个完整的示例:假设项目结构:public/static/data.jsonsrc/utils/request.jsviews/SomeComponent.vue在SomeComponent.vue请求:```javascriptimportrequestfrom'@/utils/request';exportdefault{created(){this.loadData();},methods:{loadData(){request.get('/static/data.json').then(data=>{console.log('获取到的数据:',data);}).catch(error=>{console.error('请求失败:',error);});}}}```这样,就可以在组件创建时请求本地JSON文件。注意:在开发环境下运行(npmrunserve)时,public目录下的文件可以通过根路径访问。在生产环境构建后(npmrunbuild),public目录下的文件会被复制到dist目录,同样可以通过根路径访问。如果遇到跨域问题,因为请求的是本地文件(同源),所以不会出现跨域问题。如果问题仍然存在,请检查:-服务器是否运行正常(开发服务器)-JSON文件路径是否正确(尝试在浏览器中直接访问http://localhost:端口号/static/data.json,看是否能下载到文件)这样,两个问题应该都能得到解决。</think>### 解决 "Can't resolve 'axios'" 错误并读取本地 JSON 文件 #### 一、解决 "Can't resolve 'axios'" 错误 1. **安装 Axios 依赖** ```bash npm install axios # 或 yarn add axios ``` - ✅ 安装后检查 `package.json` 的 `dependencies` 中是否包含 `"axios"` 2. **验证安装** ```javascript // 测试文件 testAxios.js import axios from 'axios'; console.log('Axios version:', axios.VERSION); ``` 3. **若安装失败** ```bash # 清除缓存并强制安装 npm cache clean --force npm install --save --legacy-peer-deps axios ``` #### 二、读取本地 JSON 文件(Vue CLI 项目) 1. **文件位置** - 将 JSON 文件放入 `public` 目录(vue-cli3+ 的静态资源目录) - 示例路径:`public/static/data.json` 2. **封装请求方法** ```javascript // src/utils/request.js import axios from 'axios'; const service = axios.create({ baseURL: process.env.BASE_URL, // 自动匹配项目域名 timeout: 5000 }); export const getLocalJson = (path) => { return service.get(`/static/${path}.json`) .then(res => res.data) .catch(error => { console.error('JSON读取失败:', error); throw error; }); }; ``` 3. **组件中使用** ```javascript // Vue组件中 import { getLocalJson } from '@/utils/request'; export default { async created() { try { const data = await getLocalJson('data'); // 读取 public/static/data.json console.log('获取的数据:', data); } catch (e) { // 错误处理 } } } ``` #### 三、常见问题解决 1. **404 错误处理** - 确认文件在 `public/static/` 目录下 - 检查文件名大小写(Linux 系统区分大小写) - 更新 `vue.config.js`(如有自定义配置): ```javascript module.exports = { publicPath: './', assetsDir: 'static' } ``` 2. **跨域问题** - 本地开发无需担心跨域,public 目录文件自动托管在根路径 - 生产环境确保 JSON 文件在部署后的 `static` 目录 3. **路径优化技巧** ```javascript // 动态路径(根据环境变量) const jsonPath = process.env.NODE_ENV === 'production' ? '/app/static/data.json' : '/static/data.json'; ``` > **重要提示**:每次修改 `public` 目录文件后需重启开发服务器 `npm run serve`[^1][^3] --- ### 工作流程示意图 ```mermaid graph LR A[创建JSON文件] --> B[放入 public/static/] B --> C[封装axios请求] C --> D[组件调用getLocalJson] D --> E{成功?} E -- 是 --> F[使用数据] E -- 否 --> G[检查路径/重启服务] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值