浅谈Nodejs应用主文件index.js


Posted in NodeJs onAugust 28, 2016

前言

经过之前的文章 《浅谈Nodejs应用的主文件index.js的组成部分》 ,终于认识了 Node 妹子的容颜,然后好像上呀<( ̄︶ ̄)>。呦西~这次让本?旁谒?靥迳嫌巫咭环??胂胍彩遣淮淼巍`藕撸?Y到此为止。

正文

这篇文章主要以组成部分为单位了解一下 index.js 这个主文件...皮肤有多滑( ̄? ̄)~

既然之前说过了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');

其实啊,依赖模块就是字面的意思。

用前端工程师的话来说,就是$("#id").attr("class","active")这句代码没有Jquery就转不起来。

用动物的话来说,没有食物就活不下去了。

用本?诺幕袄此担?挥忻米右不畈幌氯チ恕?/p>

嗯哼~综上所述,依赖就是 为接下来要做的事做好能完成该事的准备 。所以上面那些“拼音”都是扮演这种角色的..

二、设置相关配置

献上该组相关代码:

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

额..就两行代码,胸比较小(  ̄? ̄),毕竟萝莉嘛,啊哈哈哈。

上面两行代码就是设置试图目录并设置 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')));

中间件,严格来说index.js中每一行都是中间件,我估计好多兄弟虽然知道中间件这个词,但还是不了解到底是什么意思,它主要是干嘛的。

所以,本?徘鬃宰攀只?艘环?钪娼鲇械囊徽磐迹?/p>

浅谈Nodejs应用主文件index.js

我相信聪明的人一下就能看懂了,毕竟本?诺幕?贸鋈ヂ粢材苤蹈?毛钱。

正经话:左边大箭头是指代码执行顺序,谁都知道 Js 是从上往下执行的,这里为了好解释中间件,把大箭头看成水流。

而在水流往下流的过程中,有个类似滤网的东西在中间卡了一层,本?磐蝗幌氲搅舜ε?な遣皇且舱庋?ò∨蓿?枷胗植徽?耍?? ̄)。

黑色的滤网,就是上面那段代码,中间件的作用就是在执行主线代码过程前、过程中、过程后的警察、门卫或者引导者。举个栗子,比如使用 bodyParser 中间件,它的作用就是解析 HTTP 请求的 body 数据解析,方便在路由中使用, cookie-parser 也是一样的道理。

在图中两个滤网中间部分,一般为路由,由它来负责返回客户端想要的页面。

这时候,眼尖的就问了,下面那个中间件为什么是红色的?而且为什么要放在路由后面执行?

问的好!我正要说呢。 熟悉Node开发的小伙伴都知道,大部分中间件一般写在路由之前,但是有时候避免不了一些不确定的错误,比如用户访问的页面不存在怎么办?开发版本错误或者正式版本错误了怎么办? 这个时候就轮到“红色”中间件出场了,没错,它主要负责善后的,一般用来处理可能发生的错误。

四、路由

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

路由可是个好人啊,客户端只需发送请求,路由就会根据请求 url 尽力的去帮你解决请求,它可以用不同的方式( get 、 post 、 put 、 del ...)去处理数据或者返回你想要的页面。总之是个有问尽力回的好银~ 其实路由也是中间件,只是它应该作为一个独立的组成部分更好。

五、开启服务

//启动服务
http.createServer(app).listen(app.get('port'), function () {
  console.log('服务启动成功,端口为:'+app.get('port'));
});

啊哈哈哈哈,终于到高潮了,Node妹子快不行了<( ̄︶ ̄)>

额。。。好像也没什么好说的,就是开启服务了。。。。。。好吧,开启服务前,要通过 http.createServer() 创建一个服务,然后调用 listen() 方法即可开启。这样整个应用就开启啦~~~ 本?拍欠?裢贾械拇蠹?芬部梢运吵┑耐苯?チ恕!=?チ恕!Hチ恕!A恕?/p>

NodeJs 相关文章推荐
nodejs中转换URL字符串与查询字符串详解
Nov 26 NodeJs
nodejs调用cmd命令实现复制目录
May 04 NodeJs
浅谈NodeJS中require路径问题
May 07 NodeJs
nodejs 的 session 简单使用
Jun 06 NodeJs
进阶之初探nodeJS
Jan 24 NodeJs
NodeJS测试框架mocha入门教程
Mar 28 NodeJs
Nodejs Express 通过log4js写日志到Logstash(ELK)
Aug 30 NodeJs
nodejs初始化init的示例代码
Oct 10 NodeJs
深入理解nodejs搭建静态服务器(实现命令行)
Feb 05 NodeJs
nodejs同步调用获取mysql数据时遇到的大坑
Mar 02 NodeJs
NodeJs之word文件生成与解析的实现代码
Apr 01 NodeJs
Nodejs实现用户注册功能
Apr 14 NodeJs
NodeJS远程代码执行
Aug 28 #NodeJs
用NodeJS实现批量查询地理位置的经纬度接口
Aug 16 #NodeJs
使用nodejs中httpProxy代理时候出现404异常的解决方法
Aug 15 #NodeJs
NodeJs的优势和适合开发的程序
Aug 14 #NodeJs
在windows上用nodejs搭建静态文件服务器的简单方法
Aug 11 #NodeJs
Nodejs抓取html页面内容(推荐)
Aug 11 #NodeJs
用nodejs的实现原理和搭建服务器(动态)
Aug 10 #NodeJs
You might like
用在PHP里的JS打印函数
2006/10/09 PHP
9段PHP实用功能的代码推荐
2014/10/14 PHP
ThinkPHP3.2.2的插件控制器功能
2015/03/05 PHP
盘点PHP和ASP.NET的10大对比!
2015/12/24 PHP
详谈phpAdmin修改密码后拒绝访问的问题
2017/04/03 PHP
CI框架网页缓存简单用法分析
2018/12/26 PHP
tp5递归 无限级分类详解
2019/10/18 PHP
Javascript浅谈之this
2013/12/17 Javascript
js实现的标题栏新消息闪烁提示效果
2014/06/06 Javascript
常用的JavaScript WEB操作方法分享
2015/02/28 Javascript
jquery实现的缩略图预览滑块实例
2015/06/25 Javascript
JavaScript操作URL的相关内容集锦
2015/10/29 Javascript
jQuery Validate表单验证深入学习
2015/12/18 Javascript
JS中生成随机数的用法及相关函数
2016/01/09 Javascript
javascript类型系统——日期Date对象全面了解
2016/07/13 Javascript
详解webpack分离css单独打包
2017/06/21 Javascript
vuex中使用对象展开运算符的示例
2017/09/25 Javascript
Vue 项目部署到服务器的问题解决方法
2017/12/05 Javascript
详解JavaScript事件循环机制
2018/09/07 Javascript
如何利用nodejs实现命令行游戏
2020/11/24 NodeJs
Python的Django框架中消息通知的计数器实现教程
2016/06/13 Python
python实现ID3决策树算法
2017/12/20 Python
Python使用matplotlib 画矩形的三种方式分析
2019/10/31 Python
Python实现敏感词过滤的4种方法
2020/09/12 Python
python元组拆包实现方法
2021/02/28 Python
Html5画布_动力节点Java学院整理
2017/07/13 HTML / CSS
HTML5是什么 HTML5是什么意思 HTML5简介
2012/10/26 HTML / CSS
怀旧香味蜡烛:Homesick
2019/11/02 全球购物
荣耀商城:HIHONOR
2020/11/03 全球购物
简历自荐信
2013/12/02 职场文书
教师自我评价范文
2013/12/16 职场文书
2014年医学生毕业自我鉴定
2014/03/26 职场文书
技术股东合作协议书
2014/12/02 职场文书
幼儿园三八妇女节活动总结
2015/02/06 职场文书
2016年庆祝六一儿童节活动总结
2016/04/06 职场文书
MyBatis自定义SQL拦截器示例详解
2021/10/24 Java/Android