nodejs教程 安装express及配置app.js文件的详细步骤


Posted in NodeJs onMay 11, 2013

安装express.js

如果你安装了npm,安装变得很简单,只需要在终端中运行下面的代码即可:

npm install express -gd

-g代表安装到NODE_PATH的lib里面,而-d代表把相依性套件也一起安装。如果?]有-g的话会安装目前所在的目录(会建立一个node_modules的文件夹),你可以透过以下指令来比较两者的不同:

npm list -g
npm list

如果没有npm,那么我可以使用github来git下来最新的express。
好了,现在你可以通过express testapp来建立express实例。以下是示例:

cd ~
express testapp
cd testapp
node app.js

这样就建立了一个testapp的nodejs应用,而app.js是默认的应用主js。下面来详细的说说app.js中的各项配置。

引入模块

var express = require('express');
 var app = module.exports = express.createServer();

require()是node.js提供的函数,可以让你引入其他模块以调用模块的函数和变量,默认下node.js会在$NODE_PATH和目前js所在目录下的node_modules文件夹下去寻找模块。require也可以用来载入自己写的模块哦~这样涉及到node.js的模块机制,后面有机会就在介绍。

第二行的express.createServer()就是在建立server,而中间的module.exports也是涉及到node.js的模块机制,以后再说。

express的app.js的详细配置说明

express.js继承自connect模块,所以如果你的node_modules文件夹下没有connect模块也是不行的。

设置views路径和模板
我们再来看下面两行:

app.set('views', __dirname + '/views');
app.set('view engine', 'jade');

上面两行是设置views文件夹,即模板文件夹,__dirname是node.js里面的全局变量,即取得执行的js所在的路径,另外__filename是目前执行的js文件名。所以,app.set(‘views', __dirname + ‘/views');是设置views的文件夹。

而app.set('view engine', 'jade');是设置express.js所使用的render engine。除了Jade之外,express.js还支持EJS(embedded javascript)、Haml、CoffeScript和jQuery template等js模板。

app.use配置

app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(__dirname + '/public'));

express.bodyParser()是Connect?冉ǖ?iddleware,设置此处可以将client提交过来的post请求放入request.body中。
express.methodOverride()也是Connect?冉ǖ模?梢孕????OST请求伪装PUT、DELETE和其他HTTP methods。
app.router()是route requests,但express.js的官方文件是这句可有可无,并且经过测试还真的是这样,不过还是写上吧。
express.static()也是一个Connect?冉ǖ?iddleware来处理静态的requests,例如css、js、img文件等。所以static()里面指定的文件夹中的文件会直接作为静态资源吐出来。

app.configure设置

app.configure('development', function(){
  app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});
app.configure('production', function(){
  app.use(express.errorHandler());
});

express.errorHandler()是Connect?冉ǖ?iddleware来?f助?理例外。??也揭露了app.configure()的令一个用法,第一个??凳?ode.js的?境?定,如此我??就可以?定在不同的?绦协h境使用不同程度的dump。PS:node.js是透?NODE_ENV?个?境??道慈〉铆h境?定,e.g.:在命令列,NODE_ENV=production node app.js就可以?入production?境。

路由和request的处理

ok,下面是nodejs处理request的内容:

app.get('/', function(req, res){
  res.render('index', {
    title: 'Express'
  });
});

上面的代码意思是,get请求根目录则调用views文件夹中的index模板,并且传入参数title为“Express”,这个title就可以在模板文件中直接使用。

在express中要处理post请求,需要使用app.post()。如下面的代码:

app.post('/add', function(req,res){
  res.render('add', {
    sum: req.body.a + req.body.b
  });
});

前面我们提到了req.body是express.bodyParser()把POST参数处理后的结果。

另外除了get和post方法,还有app.all()意思就是所有的请求处理。

添加listen,启动nodejs服务器

app.listen(3000);
console.log(
    "Express server listening on port %d in %s mode",
    app.address().port, 
    app.settings.env);

到目前为止,我们就基本全明白了express配置了,也就不会像以前那样跟别人都写个hello world却不知道各行代码的含义了。

转自 JS8.IN ™

NodeJs 相关文章推荐
nodejs win7下安装方法
May 24 NodeJs
轻松创建nodejs服务器(6):作出响应
Dec 18 NodeJs
轻松创建nodejs服务器(10):处理上传图片
Dec 18 NodeJs
nodejs URL模块操作URL相关方法介绍
Mar 03 NodeJs
Nodejs Express4.x开发框架随手笔记
Nov 23 NodeJs
NodeJS仿WebApi路由示例
Feb 28 NodeJs
Nodejs基于LRU算法实现的缓存处理操作示例
Mar 17 NodeJs
详解nodejs微信公众号开发——6.自定义菜单
Apr 13 NodeJs
基于Koa(nodejs框架)对json文件进行增删改查的示例代码
Feb 02 NodeJs
M2实现Nodejs项目自动部署的方法步骤
May 05 NodeJs
监控Nodejs的性能实例代码
Jul 02 NodeJs
Nodejs 微信小程序消息推送的实现
Jan 20 NodeJs
nodejs中exports与module.exports的区别详细介绍
Jan 14 #NodeJs
nodejs的require模块(文件模块/核心模块)及路径介绍
Jan 14 #NodeJs
windows系统下简单nodejs安装及环境配置
Jan 08 #NodeJs
NodeJs中的非阻塞方法介绍
Jun 05 #NodeJs
nodejs win7下安装方法
May 24 #NodeJs
NodeJS的模块写法入门(实例代码)
Mar 07 #NodeJs
nodejs入门详解(多篇文章结合)
Mar 07 #NodeJs
You might like
php实现jQuery扩展函数
2009/10/30 PHP
PHP 文件上传源码分析(RFC1867)
2009/10/30 PHP
php模拟用户自动在qq空间发表文章的方法
2015/01/07 PHP
分享常见的几种页面静态化的方法
2015/01/08 PHP
php使用CutyCapt实现网页截图保存的方法
2016/10/03 PHP
js中substr,substring,indexOf,lastIndexOf的用法小结
2013/12/27 Javascript
JavaScript将页面表格导出为Excel的具体实现
2013/12/27 Javascript
jquery禁用右键示例
2014/04/28 Javascript
关于Stream和Buffer的相互转换详解
2017/07/26 Javascript
javascript 面向对象实战思想分享
2017/09/07 Javascript
详解Vue单元测试Karma+Mocha学习笔记
2018/01/31 Javascript
基于vue打包后字体和图片资源失效问题的解决方法
2018/03/06 Javascript
JavaScript实现简单动态进度条效果
2018/04/06 Javascript
VueQuillEditor富文本上传图片(非base64)
2020/06/03 Javascript
轻松掌握python设计模式之策略模式
2016/11/18 Python
使用Python处理BAM的方法
2018/09/28 Python
浅谈Pycharm中的Python Console与Terminal
2019/01/17 Python
Python如何处理大数据?3个技巧效率提升攻略(推荐)
2019/04/15 Python
简单了解python协程的相关知识
2019/08/31 Python
Pandas-Cookbook 时间戳处理方式
2019/12/07 Python
django框架基于queryset和双下划线的跨表查询操作详解
2019/12/11 Python
jenkins+python自动化测试持续集成教程
2020/05/12 Python
高考考python编程是真的吗
2020/07/20 Python
python 实现图片修复(可用于去水印)
2020/11/19 Python
jupyter notebook远程访问不了的问题解决方法
2021/01/11 Python
深入解析HTML5中的Blob对象的使用
2015/09/08 HTML / CSS
联想加拿大官方网站:Lenovo Canada
2018/04/05 全球购物
台湾7-ELEVEN线上购物中心:7-11
2021/01/21 全球购物
绿色城市实施方案
2014/03/19 职场文书
法人代表证明书格式
2014/10/01 职场文书
2014年保洁工作总结
2014/11/24 职场文书
房屋授权无偿使用证明
2014/11/29 职场文书
2014城乡环境综合治理工作总结
2014/12/19 职场文书
物业前台接待岗位职责
2015/04/03 职场文书
HTML+css盒子模型案例(圆,半圆等)“border-radius” 简单易上手
2021/05/10 HTML / CSS
Python万能模板案例之matplotlib绘制甘特图
2022/04/13 Python