【Nodejs开发技术】浅谈Nodejs应用的主文件index.js的组成部分

转载 2016年08月28日 20:06:00

前言

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的大概目录,不难发现,它有几个重要的部分组成:

  1. 引入依赖模块

  2. 设置相关配置

  3. 定义中间件

  4. 定义路由

  5. 开启服务

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

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

  1. 引入依赖模块

  2. 设置相关配置

  3. 连接数据库(可选)

  4. 定义中间件

  5. 定义路由

  6. 开启服务

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

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

总结

一个完整的index.js由7个部分组成,大家只要把主文件当成白雪公主,把7个组成部分当作七个小矮人就行了,哈哈,这个记法真天才。

不过话说回来,并不是每个应用都必须7个大将全上场,可能是5个,可能是6个,也可能是7个,大家在组织代码的时候根据应用和硬件需求来自定义构建即可。


原文地址:https://segmentfault.com/a/1190000006625764

【关于我们】

每天名企社招内推微信公众号ourpush),专注于国内各大互联网公司社会招聘内推。每天更新最新互联网名企(包括但不限于BAT网易小米京东乐视携程等名企)内推信息,有技术岗、有产品岗、有运营岗、有设计岗、有交互岗、有销售岗,更有其他N多相关岗位!更多内推信息请扫描以下二维码关注查阅。




相关文章推荐

采用基于NodeJS的express+Mongodb技术快速开发web应用

使用Node.js实现一个微博系统。功能包括路由控制、页面模块、数据库访问、用户注册、登陆、用户会话等内容。 主界面采用bootstrap框架。效果图: 本系统采用MVC的设计模式expres...

腾讯后台开发技术总监浅谈过载保护 小心雪崩效应

本文转自:http://www.mysqlops.com/2012/05/10/protect.html 摘要: 每个系统,都有自己的最大处理能力,后台技术人员对此必须很清楚,且要注意自我保护,...

腾讯后台开发技术总监浅谈过载保护 小心雪球效应

摘要: 每个系统,都有自己的最大处理能力,后台技术人员对此必须很清楚,且要注意自我保护,不然就会被雪球压垮。 雪球:      对于时延敏感的服务,当外部请求超过系统处理能力,如果系统没有做相应保...

浅谈Android开发技术层次

任何一种移动开发生态系统其技术人员都是呈现金字塔式分布的。大多数属于开发人员,少数为真正意义上的程序员。 1、应用层开发 使用java语言,基于android的框架和类库,进行应用层程序的...
  • xmyzlz
  • xmyzlz
  • 2013年02月20日 11:20
  • 459

腾讯后台开发技术总监浅谈过载保护 小心雪崩效应

摘要: 每个系统,都有自己的最大处理能力,后台技术人员对此必须很清楚,且要注意自我保护,不然就会被雪球压垮,出现雪崩。 雪球: 对于时延敏感的服务,当外部请求超过系统处理能力,如果系统没有...

使用nodejs插件UglifyJS2压缩js文件

  • 2017年06月10日 22:43
  • 64KB
  • 下载

插件开发技术说明(17)---应用CRUD开发模式范例

对一个数据库表进行增,删,修改,查询操作是常见的编程任务. 统一和简化此类开发任务,可以提高开发效率,包括实现,调试和维护. 本文以常购商品的功能为例,说明基于需求完整实现的过程. 1.功能与...
  • wherwh
  • wherwh
  • 2015年10月10日 21:08
  • 421

NodeJS笔记 一个完整的基于Node.js的web应用

作者: Manuel Kiessling 翻译: goddyzhao & GrayZhang & MondayChen 关于 本书致力于教会你如何用Node.js来开发应用,过程中会传授你...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【Nodejs开发技术】浅谈Nodejs应用的主文件index.js的组成部分
举报原因:
原因补充:

(最多只允许输入30个字)