vue 项目如何读取本地json文件数据

在项目根目录有一个static文件夹目录,将所需要的json文件放在该static目录下,使用axios发起get请求获取对应的json文件数据

import axios from 'axios'  // 安装axios后引入
Vue.prototype.$axios = axios  // 将axios挂载到原型上方便使用
 
// 使用get请求获取到static目录下的 test.json文件的数据

this.$axios.get('/static/test.json').then(res => {    
    console.log(res)
})

在vue-cli3及以上版本创建的项目这样请求会报404错误,原因是vue-cli3.0之后创建的项目静态资源都放在了根目录下的public目录下,因此需要将json文件建在public目录下,
请求的地址需要改变,如下:

this.$axios.get('/test.json').then(res => {      // 获取public下的test.json文件数据
    console.log(res)
})

经测试,public中嵌套文件夹后仍然可以读取

// 获取public下 data 文件夹中的test.json文件数据
import axios from 'axios'
// 局部使用
const service = axios.create({ 
baseURL: '', // 请求本地json文件,那么baseURL取空字符串,域名就会是项目域名
timeout: 30000,
});
service.get('/data/test.json').then(res => {      
    console.log(res)
})

https://www.i4k.xyz/article/Boale_H/107039649

    原文作者:shiyue41
    原文地址: https://blog.csdn.net/qq_27694835/article/details/125476996
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞