前言

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个,大家在组织代码的时候根据应用和硬件需求来自定义构建即可。

浅谈Nodejs应用的主文件index.js的组成部分的更多相关文章

  1. 浅谈nodejs和php

    现在,Web开发公司和开发人员可以选择多种技术栈来构建Web应用程序.早期网络发展,不同的技术被用于前端和后端开发.但是,随着Node.js的发布,布局发生了变化,因为它允许开发人员使用 JavaSc ...

  2. 浅谈nodejs中HTTP模块应用

    这里给大家分享下后端人员如果利用nodejs对数据的一些处理情况  适用于初学者使用 大牛勿喷 给大家分享下主要后端思想部分代码,前端部分就不展示了 const http = require(&quo ...

  3. 浅谈nodejs与npm

    (1)npm介绍 在正式介绍Node.js学习之前,我们先认识一下npm. npm是什么东西?npm其实是Node.js的包管理工具(package manager). 为啥需要一个包管理工具呢?因为 ...

  4. 浅谈NodeJS多进程服务架构基本原理

    阅读目录 一:nodejs进程进化及多进程架构原理 二:node中child_process模块实现多进程 三:父子进程间如何通信? 四:理解cluster集群 回到顶部 一:nodejs进程进化及多 ...

  5. 浅谈NodeJs的模块机制

    J历史 我们都知道,js在刚被创建的时候,只是为了在网页上写一些小脚本而已,比如网页特效,表单验证等等,创立者也许没觉悟到以后的js会发展到如此规模.这是web1.0时代. 在web 2.0时代,各种 ...

  6. 60.浅谈nodejs中的Crypto模块

    转自:https://www.cnblogs.com/c-and-unity/articles/4552059.html node.js的crypto在0.8版本并没有改版多少,这个模块的主要功能是加 ...

  7. 浅谈PHP中的数组和JS中的数组

    最近在做前后端对接的时候,遇到一个问题,前端要求返回的数据格式是左边的,但是我通过json_encode返回到的数据格式是右边的   注意:数据格式从"[]"(数组)变成了&quo ...

  8. 【前端知识体系-NodeJS相关】浅谈NodeJS中间件

    1. 中间件到底是个什么东西呢? [!NOTE] 中间件其是一个函数,在响应发送之前对请求进行一些操作 function middleware(req,res,next){ // 做该干的事 // 做 ...

  9. 【微信小程序项目实践总结】30分钟从陌生到熟悉 web app 、native app、hybrid app比较 30分钟ES6从陌生到熟悉 【原创】浅谈内存泄露 HTML5 五子棋 - JS/Canvas 游戏 meta 详解,html5 meta 标签日常设置 C#中回滚TransactionScope的使用方法和原理

    [微信小程序项目实践总结]30分钟从陌生到熟悉 前言 我们之前对小程序做了基本学习: 1. 微信小程序开发07-列表页面怎么做 2. 微信小程序开发06-一个业务页面的完成 3. 微信小程序开发05- ...

随机推荐

  1. Python:在一个Python程序中,运行另一个Python程序

    学习自: 1~3学习自如何在python中执行另一个py文件_python_脚本之家 4~6学习自Python中四种运行其他程序的方式 - hankleo - 博客园 1.os.system方法 用法 ...

  2. Scrapy(五):Response与Request、数据提取、Selector、Pipeline

    学习自Requests and Responses - Scrapy 2.5.0 documentation Request在Spider中生成,被Downloader执行,之后会得到网页的Respo ...

  3. JZ-006-旋转数组的最小数字

    旋转数组的最小数字 题目描述 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. NOTE:给出的所有元素都大于0,若数组 ...

  4. Dubbo是什么?核心总结

    Dubbo --是SOA架构的具体的实现框架! 2.1 Dubbo简介 Apache Dubbo是一款高性能的Java RPC框架.官网地址:[http://dubbo.apache.org] dub ...

  5. Linux网卡ifcfg-eth0配置详解

    DEVICE="eth1"                              网卡名称 NM_CONTROLLED="yes"            n ...

  6. linux su、sudo、sudo su、sudo -i的用法和区别

    sudo : 暂时切换到超级用户模式以执行超级用户权限,提示输入密码时该密码为当前用户的密码,而不是超级账户的密码.不过有时间限制,Ubuntu默认一次时长15分钟. su : 切换到某某用户模式,提 ...

  7. laravel 使用Redis

    1.非框架中使用redis实例? 就是new出redis对象然后连接,然后键值操作即可 <?php $redis = new redis(); $redis->connect('127.0 ...

  8. 4月28日 python学习总结 线程与协程

    一. 异步与回调机制 问题: 1.任务的返回值不能得到及时的处理,必须等到所有任务都运行完毕才能统一进行处理 2.解析的过程是串行执行的,如果解析一次需要花费2s,解析9次则需要花费18s 解决一: ...

  9. [源码解析] TensorFlow 分布式环境(4) --- WorkerCache

    [源码解析] TensorFlow 分布式环境(4) --- WorkerCache 目录 [源码解析] TensorFlow 分布式环境(4) --- WorkerCache 1. WorkerCa ...

  10. Python编写简易木马程序(转载乌云)

    Python编写简易木马程序 light · 2015/01/26 10:07 0x00 准备 文章内容仅供学习研究.切勿用于非法用途! 这次我们使用Python编写一个具有键盘记录.截屏以及通信功能 ...