资讯专栏INFORMATION COLUMN

浅谈Nodejs应用的主文件index.js的组成部分

Profeel / 1729人阅读

摘要:搭建一个应用,少不了一个主文件,不少人根据各自喜好来定义名字,像。总结一个完整的由个部分组成,大家只要把主文件当成白雪公主,把个组成部分当作七个小矮人就行了,哈哈,这个记法真天才。

前言

Node妹子的问世,着实让我们前端攻城狮兴奋了一把,尤其本屌听说Javascript可以写服务端后,兴奋的像是看到了二次元萝莉的胖子...(●"◡"●)。呃哼...YY先到这里,原谅本屌是个二次元萝莉控。

正文

想谈好对象,并不是要new一个就行了,必须要先认识人家后慢慢的才可以上手,然后慢慢推上床<( ̄︶ ̄)>。
想想自己搞前端开发的时候,为了尽力让页面在浏览器君体内完美展现,也是做了不少功课,其中最不可少的就是要认识认识。这玩意是什么,能干什么。
对于寄宿在浏览器中的Javascript就不多说了,之前发过一篇简单的文章《前端Javascript与Nodejs的异同》
,大概描述了下Nodejs与前端javascript的异同,如果你好好看的话肯定能明白的。

index.js

搭建一个Node应用,少不了一个主文件,不少人根据各自喜好来定义名字,像app.jsmain.js
这里尊重npm init时的默认配置为index.js,其实个人还是挺喜欢app.js这个命名的。
为了方便,本屌也使用了express这个高大上的框架。
好!!!下面,我们来看看index.js里应该有的内容。

//引用依赖模块
var express = require("express");
var path = require("path");
var favicon = require("serve-favicon");
var logger = require("morgan");
var cookieParser = require("cookie-parser");
var bodyParser = require("body-parser");

var routes = require("./routes/index");
var users = require("./routes/users");

var app = express();

// 视图引擎设置
app.set("views", path.join(__dirname, "views"));
app.set("view engine", "jade");

//中间件
app.use(favicon(path.join(__dirname, "public", "favicon.ico")));
app.use(logger("dev"));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, "public")));

//路由
app.use("/", routes);
app.use("/users", users);

//遇到错误时的中间件
app.use(function(req, res, next) {
  var err = new Error("Not Found");
  err.status = 404;
  next(err);
});

if (app.get("env") === "development") {
  app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render("error", {
      message: err.message,
      error: err
    });
  });
}

app.use(function(err, req, res, next) {
  res.status(err.status || 500);
  res.render("error", {
    message: err.message,
    error: {}
  });
});

//抛出 提供给www.js 并通过www.js来开启服务
module.exports = app;

以上代码是通过express脚手架生成的一个比较标准的内容,个人在里面做了简单的注释。然后我想说,请童鞋们不要急着看每一行代码是什么意思,因为如果你熟悉nodejs不用看也知道写的什么,如果你不了解,也暂时不要去了解,我们看一本新书的时候,一定要先看一下它的目录才能大概知道书的内容。
现在我们来整理一下这个index.js的大概目录,不难发现,它有几个重要的部分组成:

引入依赖模块

设置相关配置

定义中间件

定义路由

开启服务

几乎所有的入口文件都少不了这几个组成部分,而且顺序也是按照上面列表从上到下依次编写。这里需要说的是中间件这一部的编写,大部分中间件是写在路由之前,但是有些中间件应该在路由之后执行,比如处理错误的中间件,一般放在路由后面执行。

其实一个完整的入口文件并不是只有上面说的那么多,它还有一些可选项来构成完整的index.js。为了方便比较,就直接列举出来吧:

引入依赖模块

设置相关配置

连接数据库(可选)

定义中间件

定义路由

开启服务

在多核系统上启动cluster多核处理模块(可选)

可以看出,添加了连接数据库和多核处理两个可选组成部分。

总结

一个完整的index.js由7个部分组成,大家只要把主文件当成白雪公主,把7个组成部分当作七个小矮人就行了,哈哈,这个记法真天才。
不过话说回来,并不是每个应用都必须7个大将全上场,可能是5个,可能是6个,也可能是7个,大家在组织代码的时候根据应用和硬件需求来自定义构建即可。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/87869.html

相关文章

  • 浅谈Nodejs应用文件index.js组成部分——略详解

    摘要:用本屌的话来说,没有妹子也活不下去了。所以,本屌亲自着手画了一幅宇宙仅有的一张图我相信聪明的人一下就能看懂了,毕竟本屌的画拿出去卖也能值个毛钱。这样整个应用就开启啦本屌那幅神图中的大箭头也可以顺畅的捅进去了。。 前言 经过之前的文章《浅谈Nodejs应用的主文件index.js的组成部分》,终于认识了Node妹子的容颜,然后好像上呀<( ̄︶ ̄)>。呦西~这次让本屌在她胴体上游走一番,想...

    DataPipeline 评论0 收藏0
  • 浅谈前后端分离与实践(一)

    摘要:前后端的界限是按照浏览器和服务器的划分。前后端彼此互不关联。关于作者本文部分图片段落参考文章实践中的前后端分离。淘宝前后端分离实践本文源码详见服务端代码。 一、起源 (故事纯属虚构,如有雷同,纯属巧合)传说在很久很久以前,我们有志之士有了个创业的想法,于是乎开始了自己的创业之梦,但是人手不足啊,于是乎所有角色老子一个人全包了: Roles: PM, DBA, RD, FED, Des...

    dantezhao 评论0 收藏0
  • 浅谈前后端分离与实践(一)

    摘要:前后端的界限是按照浏览器和服务器的划分。前后端彼此互不关联。关于作者本文部分图片段落参考文章实践中的前后端分离。淘宝前后端分离实践本文源码详见服务端代码。 一、起源 (故事纯属虚构,如有雷同,纯属巧合)传说在很久很久以前,我们有志之士有了个创业的想法,于是乎开始了自己的创业之梦,但是人手不足啊,于是乎所有角色老子一个人全包了: Roles: PM, DBA, RD, FED, Des...

    yy13818512006 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<