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


    前言

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

  • 相关阅读:
    响应式设计
    Flex box 弹性盒子布局
    下拉菜单  -
    html使用技巧
    nth-of-type(n)
    Js中 关于top、clientTop、scrollTop、offsetTop
    仿iPhone滑屏操作
    网页超过一页 点击回到顶部
    linux svn使用
    Linux查看CPU和内存使用情况
  • 原文地址:https://www.cnblogs.com/10manongit/p/12933360.html
Copyright © 2020-2023  润新知