js读取本地json_vue读取本地json文件

js读取本地json_vue读取本地json文件data.json文件内容{"code":0,"msg":"请求成功","data":[{"name&am

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

第一步:准备本地JSON文件

F:\nodejs\data\test.json

{ 
   
    "code": 0,
    "msg": "请求成功",
    "data": [
        { 
   
            "name": "zhangsan",
            "age": 50
        },
        { 
   
            "name": "lisi",
            "age": 32
        },
        { 
   
            "name": "wangwu",
            "age": 17
        }
    ]
}

第二步:编写nodejs服务程序

F:\nodejs\express.js

var express = require('express'); //express框架模块
var path = require('path'); //系统路径模块
var fs = require('fs'); //文件模块
var bodyParser = require('body-parser'); //对post请求的请求体进行解析模块
var app = express();
app.use(bodyParser.urlencoded({ 
    extended: false })); //bodyParser.urlencoded 用来解析request中body的 urlencoded字符,只支持utf-8的编码的字符,也支持自动的解析gzip和 zlib。返回的对象是一个键值对,当extended为false的时候,键值对中的值就为'String'或'Array'形式,为true的时候,则可为任何数据类型。

//设置允许跨域请求
app.all('*', (req, res, next) => { 
   
    res.header('Access-Control-Allow-Origin', '*'); //访问控制允许来源:所有
    res.header('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept'); //访问控制允许报头 X-Requested-With: xhr请求
    res.header('Access-Control-Allow-Metheds', 'PUT, POST, GET, DELETE, OPTIONS'); //访问控制允许方法
    res.header('X-Powered-By', 'nodejs'); //自定义头信息,表示服务端用nodejs
    res.header('Content-Type', 'application/json;charset=utf-8');
    next();
});

//创建get接口
app.get('/api', (req, res) => { 
   
	
	//console.log(req.body); //获取请求参数
	
    var file = path.join(__dirname, 'data/test.json'); //文件路径,__dirname为当前运行js文件的目录
    //var file = 'f:\\nodejs\\data\\test.json'; //也可以用这种方式指定路径
	
	//读取json文件
    fs.readFile(file, 'utf-8', function(err, data) { 
   
        if (err) { 
   
            res.send('文件读取失败');
        } else { 
   
            res.send(data);
        }
    });
});

var hostName = '127.0.0.1'; //ip
var port = 8888; //端口
app.listen(port, hostName, () => { 
   

    console.log(`服务器运行在http://${ 
     hostName}:${ 
     port}`);

});

第三步: 测试请求接口数据

axios.get('http://127.0.0.1:8888/api')
  .then((response) => { 
   
    console.log(response);
  })
  .catch((error) => { 
   
    console.log(error);
  });
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182797.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 有效沟通技巧

    有效沟通技巧【管理名言】面对面的沟通是最好的沟通方式沟通的三个行为:说、听、问要形成一个双向的沟通,必须包含三个行为,即:有说的行为、听的行为和问的行为。一个有效的沟通技巧就是由这三种行为组成的。换句话说,考核一个人是否具备沟通技巧的时候,看他这三种行为是否都出现。【案例分析】一家著名的公司在面试员工的过程中,经常会让10个应聘者在一个空荡的会议室里一起做一个小游戏,很…

    2022年6月16日
    22
  • 51单片机最小系统的制作

    51单片机最小系统的制作本文将介绍如何自制一个51单片机最小系统及一些附加模块。最终制成的系统将具有烧录程序,运行程序等功能。先放两张张最终成品如下 ​                                        (正面)                  (反面–锡接走线法)提醒读者,下载口的布局有点

    2022年6月23日
    25
  • 内核NFS-V4部署服务,挂载,ACL使用

    内核NFS-V4部署服务,挂载,ACL使用

    2022年4月2日
    168
  • softmax函数导数「建议收藏」

    大家好,又见面了,我是你们的朋友全栈君。

    2022年4月14日
    46
  • 多线程(二)—-线程的启动方式(一)

    多线程(二)—-线程的启动方式(一)

    2020年11月12日
    194
  • 微信不能登录网页版(微信手机网页登录)

     因为出于工作和学习的目的,我的个人电脑操作系统使用的是Ubuntu18.04LTS,就目前而言,许多优秀的软件都有Linux版本,虽然Linux的用户相对群体较小,但是其软件生态也在逐渐成长,而且日常使用浏览器就可以解决许多的应用需求。现在微信和QQ在生活和工作领域均是举足轻重,emm…  BUT!!!腾讯到目前为止并没有推出Linux版的微信和TI…

    2022年4月12日
    61

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号