NodeJs本地搭建服务器,模拟接口请求,获取json数据

引言:
不知道你在项目开发过程中,有没有遇到过有过以下场景:
一般是前端先制作静态页面,同时服务器端创建数据库,搭服务器端架构,写接口;
当接口写完之后,前端或者后端才能嵌套页面。
但是,如果前端页面制作好了,后端接口还没有写好呢?或者如何让前端、后端各自做各自的事情,互相不影响?
能做到下面这样是不是很好呢?
——在进行完需求分析和详细设计后,前端、后端一同商量、制作出一份接口文档
(其中接口名、参数、返回值名称、返回值类型都定义好)
前端页面制作好之后,直接模拟出该接口的json文件,先去请求该文件,把页面绑定、业务逻辑都处理好。
等前端全部绑定好,同时后端接口写好后,我们只需要前端修改接口地址,其他不用做任何修改。
这样,是不是前端不用等后端接口全部写完才能开始剩下的工作。

1.创建一个最简单的项目

  • 安装nodejs
  • 新建一个文件夹,进入目录
mkdir express
  • 接下来安装 Express
npm install -g express-generator@4
  • 创建一个工程
express helloworld
现在在express文件夹下就出现了helloworld项目
  • 安装依赖
cd helloworld
npm install
 备注:执行npm install命令会将package.json文件中 dependencies 依赖列表中,
即可自动安装依赖列表中所列出的所有模块。
  • 开启服务
执行npm start命令
  • 这样就可以在浏览器访问
http://localhost:3000/

下面是浏览器中显示的内容

pic1.png

2.为什么浏览器中出现的内容是这样的呢?

  • 首先我们打开app.js,然后可以找到这句话
app.use('/', routes);
  • 然后我们再看routes是什么,就可以往上找,找到
var routes = require('./routes/index');
  • 顺着这个,我们打开routes文件夹下的index.js文件,看看里面究竟写的是什么
  var express = require('express');
  var router = express.Router();
  /* GET home page. */
  router.get('/', function(req, res, next) {
    res.render('index', { title: 'Express' });
  });
  module.exports = router;
  • 原来框架是找到views文件夹下的index.jade文件渲染到前台页面
  index.jade
  extends layout

  block content
    h1= title
    p Welcome to #{title}
  • 这里我们先不用管 <u><b>模板引擎</b></u> 的语法,试着修改修改index.js文件的内容,将title改为Hello world.
var express = require('express');
    var router = express.Router();
    /* GET home page. */
    router.get('/', function(req, res, next) {
      res.render('index', { title: 'Hello world.' });
    });
    module.exports = router;
  • 在命令行中,按ctrl+c关闭服务,重新执行npm start,看界面中的结果
pic2.png

是不是很简单。

3.看到这里,可能有个疑问,我们怎么访问静态的html呢?
很简单,下面一步步说来:

  • 首先,我们看app.js中有没有这句话
app.use(express.static(path.join(__dirname, 'public')));
  • 有的话,则直接看下一步,没有就在app.js中添加这句话,记得添加后重启服务
  • 接着,我们在项目的public文件夹下,新建一个html文件下(便于后期管理所有的静态页面),然后新建index.html,内容如下:
 <!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>demo</title>
</head>
<body>
   Hello world.
</body>
</html>

这样在浏览器中输入下面的地址,就可以访问了。

http://localhost:3000/html/index.html

4.我们现在做到了能访问一个html文件,那我们如何模拟ajax请求,读取json文件中的内容,提前绑定页面呢?(不依赖后端接口写好)

  • 为了方便项目管理,我们新建几个文件夹和对应的文件
json文件夹及其对应的index.json文件
在javascripts文件夹下新建index.js
index.json
{
    "code":"200",
    "msg":"success"
}
index.js
fetch("../json/index.json").then(function(res) {
  if (res.ok) {
    res.json().then(function(data) {
      console.log(data);
    });
  } else {
    console.log("Looks like the response wasn't perfect, got status", res.status);
  }
}, function(e) {
  console.log("Fetch failed!", e);
});
  • 在index.html中引入对应的文件
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>demo</title>
</head>
<body>
    Hello world.
    <script src="../javascripts/index.js"></script>
</body>
</html>
pic3.png

5.最后附上项目结构

pic4.png

有关fetch的用法,可以查看GitHub上的 这个项目

快动手尝试一下吧,以后前端开发再也不用等服务器端框架搭好,接口写好了。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352

推荐阅读更多精彩内容