前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >我的NodeJS学习之路4(初始配置)

我的NodeJS学习之路4(初始配置)

作者头像
飞奔去旅行
发布2019-06-13 14:13:33
1.1K0
发布2019-06-13 14:13:33
举报
文章被收录于专栏:智慧协同智慧协同

小弟初涉node领域,不足之处,还请多多指教! 欢迎Star、Fork:https://github.com/gefangshuai/ANodeBlog


整个工程结构已经有了,下面来说一下几个简单但重要的配置:

定义一个简单的配置文件,存放项目配置信息

一个完整的项目中,会有各种配置信息,如何组织这些信息,会给我们后期的维护成本带来不同的影响。 为了更好的维护项目,我习惯定义一个配置文件来专门组织这些信息,我们可以命名为config.js,放到项目根目录下,直观表现。

加入一个全局filter,用于向所有请求传递相同的参数

类似“站点信息”这种常量参数,在每个页面中可能我们都要用它来展示在页面上,我们不可能在所有的请求每次都render一次这些信息。需要有一个统一的管理,我称之为filter。将这个filter定义在所有的请求之上。node执行顺序是从上往下,所以每个请求在页面上都会拿到这些参数。

代码语言:javascript
复制
/**
 * 全局参数传递
 */
app.use(function (req, res, next) {
    res.locals.site = config.site;
    res.locals.success = req.flash(config.constant.flash.success);
    res.locals.error = req.flash(config.constant.flash.error);
    res.locals.session = req.session;
    next();
});

与handlebars模版集成.

新建好的工程默认使用的是hbs,相似的还有express-handlebarsexpress-hbs,三者除了用法,功能上没有太大的区别,都是针对Handlebars后台模版引擎的一个封装,选择哪个,看个人习惯。本例中使用express-handlebars

卸载hbs

代码语言:javascript
复制
npm uninstall hbs

安装express-handlebars

代码语言:javascript
复制
npm install --save express-handlebars

修改模版集成 在app.js中添加express-handlebars*

代码语言:javascript
复制
var exphbs = require('express-handlebars');

修改视图引擎配置 在

代码语言:javascript
复制
app.set('view engine', 'hbs');

上面添加下面代码:

代码语言:javascript
复制
var hbs = exphbs.create({
    partialsDir: 'views/partials',
    layoutsDir: "views/layouts/",
    defaultLayout: 'main',
    extname: '.hbs'
});
app.engine('hbs', hbs.engine);

整个代码看起来是这样的:

代码语言:javascript
复制
var hbs = exphbs.create({
    partialsDir: 'views/partials',
    layoutsDir: "views/layouts/",
    defaultLayout: 'main',
    extname: '.hbs'
});
app.engine('hbs', hbs.engine);
app.set('view engine', 'hbs');

说明:

  • partialsDir: 指定partial页面的目录。
  • layouts:指定布局页面的目录
  • defaultLayout:指定默认布局文件(没带后缀)
  • extname: 指定handlebars文件后缀(不得不吐槽“handlebars”字母太长,所以改的简单点)

与Session集成

web应用中,session是不可获取的重要部分,从express4开始,session作为一个独立的中间件而不再直接集成于express框架中,我们需要单独安装使用。

代码语言:javascript
复制
npm install --save express-session

然后在app.js中require

代码语言:javascript
复制
var session = require('express-session');

定义它:

代码语言:javascript
复制
app.use(session({
    secret: config.db.cookieSecret,
    cookie: {maxAge: 30 * 60 * 1000}
}));
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016.01.21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 定义一个简单的配置文件,存放项目配置信息
  • 加入一个全局filter,用于向所有请求传递相同的参数
  • 与handlebars模版集成.
  • 与Session集成
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档