Nodejs的express使用教程


Posted in NodeJs onNovember 23, 2015

Express 是一个简洁、灵活的 node.js Web 应用开发框架, 它提供一系列强大的特性,帮助你创建各种 Web 和移动设备应用。

1.express组织结构

app demo

    |---node_modules------用于安装本地模块。
    |---public------------用于存放用户可以下载到的文件,比如图片、脚本、样式表等。
    |---routes------------用于存放路由文件。
    |---views-------------用于存放网页的模板。
    |---app.js------------应用程序的启动脚本。
    |---package.json------项目的配置文件。

2..创建express服务器

//app.js文件
var express = require('express');
var app = express();
//指定更目录显示的内容
app.get('/', function(req, res){
 res.send('Hello World');
});
//指定监听端口
var server = app.listen(3000, function() {
  console.log('Listening on port %d', server.address().port);
});

运行nodejs应用程序

/>node app.js

3.中间件

中间件(middleware)就是处理HTTP请求的函数.
当一个HTTP请求进入服务器,服务器实例会调用第一个中间件,完成后根据设置,决定是否再调用下一个中间件.

中间件的参数为:

.四个的时候---第一个为错误处理,第二个为客户请求request,第三个为服务器响应respond,第四个为next中间件. 如function(error, request, response, next){}
.三个的时候---第一个客户请求request,第二个为服务器响应respond,第三个为next中间件. 如function(request, response, next){}
.两个的时候---第一个客户请求request,第二个为服务器响应respondfunction. 如function(request, response){}

4.使用中间件use

use是express调用中间件的方法,它返回一个函数.

app.use(function(request, response) {
 response.writeHead(200, { "Content-Type": "text/plain" });
 response.end("Hello world!\n");
});

5.错误内容显示

app.use(express.bodyParser());//使用body参数
app.use(express.methodOverride());//使用函数覆盖
app.use(app.router);//使用路由
app.use(function(err, req, res, next){
 console.error(err.stack);
 res.send(500, 'Something broke!');
});//错误内容显示

6.路由

express路由的方式有多种,这里举例常用的几种:

.app.use('/', middleware);//get/post时,对于路径/的处理
.app.get("/", middleware);//http中get时,对于路径/的处理
.app.post("/", middleware);//http中post时,对于路径/的处理
.app.put("/", middleware);//http中put时,对于路径/的处理
.app.delete("/", middleware);//http中delete时,对于路径/的处理

7.路径通配符*

.*表示所有路径

app.get("*", function(request, response) {
 response.end("404!");
});//所有路径都返回404

.:捕获路径内容

app.get("/hello/:who", function(req, res) {
 res.end("Hello, " + req.params.who + ".");
});//如"/hello/alice”网址,网址中的alice将被捕获,作为req.params.who属性的值

8.设置环境变量set

set用于指定变量的值.
app.set("view engine", "ejs");//使用ejs作为模版

9.response对象方法

.重定向redirect

    response.redirect("/hello/anime");//重定向到/hello/anime

.发送文件sendFile

   response.sendFile("/path/to/anime.mp4");

.渲染网页模板render,即把变换的内容加载到网页.
    response.render("index", { message: "Hello World" });//将message变量传入index模板,值为"Hello World"渲染成HTML网页

10.requst对象方法

.获取客户ip地址:request.ip

.获取上传的文件:request.files

11.启动脚本package.json

package.json用于指定app信息,nodejs版本号和其他组件的依赖关系

{
  "name": "demo",
  "description": "My First Express App",
  "version": "0.0.1",
  "dependencies": {
   "express": "3.x"
  }
}

12.app入口app.js

app.js主要包含http的创建,基本路由,监听端口号

13.动态网页模板views

views文件夹,用于存放所有的放网页模板.

//app.js
app.get('/', function(req, res) {
  res.render('index',{title:"最近文章"});
});
//index.js
this is <%=title%>!

14.指定静态网页目录

//app.js
app.use(express.static('public'));//指定静态网页目录,当浏览器发出非HTML文件请求时,服务器端就到public目录寻找这个文件

如:<link href="/bootstrap/css/bootstrap.css" rel="stylesheet">, 服务器端就到public/bootstrap/css/目录中寻找bootstrap.css文件

好了,本教程先给大家介绍到这里,后续还会持续给大家更新,谢谢大家一直以来对三水点靠木网站的支持。!

NodeJs 相关文章推荐
使用Nodejs开发微信公众号后台服务实例
Sep 03 NodeJs
基于NodeJS的前后端分离的思考与实践(五)多终端适配
Sep 26 NodeJs
详解nodeJS中读写文件方法的区别
Mar 06 NodeJs
Nodejs 获取时间加手机标识的32位标识实现代码
Mar 07 NodeJs
NodeJS实现图片上传代码(Express)
Jun 30 NodeJs
nodeJS(express4.x)+vue(vue-cli)构建前后端分离实例(带跨域)
Jul 05 NodeJs
Nodejs使用Mongodb存储与提供后端CRD服务详解
Sep 04 NodeJs
nodejs遍历文件夹下并操作HTML/CSS/JS/PNG/JPG的方法
Nov 01 NodeJs
nodejs使用async模块同步执行的方法
Mar 02 NodeJs
nodejs微信开发之授权登录+获取用户信息
Mar 17 NodeJs
Nodejs实现用户注册功能
Apr 14 NodeJs
Nodejs封装类似express框架的路由实例详解
Jan 05 NodeJs
nodejs初步体验篇
Nov 23 #NodeJs
Nodejs初级阶段之express
Nov 23 #NodeJs
基于html5和nodejs相结合实现websocket即使通讯
Nov 19 #NodeJs
浅析nodejs实现Websocket的数据接收与发送
Nov 19 #NodeJs
Nodejs实战心得之eventproxy模块控制并发
Oct 27 #NodeJs
浅谈Nodejs观察者模式
Oct 13 #NodeJs
使用Angular和Nodejs、socket.io搭建聊天室及多人聊天室
Aug 21 #NodeJs
You might like
博士208HAF收音机实习报告
2021/03/02 无线电
关于mysql字符集设置了character_set_client=binary 在gbk情况下会出现表描述是乱码的情况
2013/01/06 PHP
CI框架中redis缓存相关操作文件示例代码
2016/05/17 PHP
基于thinkPHP框架实现留言板的方法
2016/10/17 PHP
IIS 7.5 asp Session超时时间设置方法
2017/04/17 PHP
Laravel 实现数据软删除功能
2019/08/21 PHP
JS实现仿新浪微博发布内容为空时提示功能代码
2015/08/19 Javascript
基于 webpack2 实现的多入口项目脚手架详解
2017/06/26 Javascript
javascript 玩转Date对象(实例讲解)
2017/07/11 Javascript
微信小程序 页面跳转传值实现代码
2017/07/27 Javascript
详解webpack的配置文件entry与output
2017/08/21 Javascript
深入浅析Vue中的Prop
2018/06/10 Javascript
vue-router 源码之实现一个简单的 vue-router
2018/07/02 Javascript
写一个Vue Popup组件
2019/02/25 Javascript
react的滑动图片验证码组件的示例代码
2019/02/27 Javascript
微信小程序3D轮播实现代码
2019/09/19 Javascript
Python数据分析之如何利用pandas查询数据示例代码
2017/09/01 Python
Python3.6安装及引入Requests库的实现方法
2018/01/24 Python
python代码过长的换行方法
2018/07/19 Python
用django设置session过期时间的方法解析
2019/08/05 Python
Python爬虫爬取煎蛋网图片代码实例
2019/12/16 Python
Python RabbitMQ实现简单的进程间通信示例
2020/07/02 Python
浅析python实现动态规划背包问题
2020/12/31 Python
python利用后缀表达式实现计算器功能
2021/02/22 Python
BCBG官网:BCBGMAXAZRIA
2017/12/29 全球购物
班级聚会策划书
2014/01/16 职场文书
清明节演讲稿
2014/05/27 职场文书
家庭贫困证明范本(经典版)
2014/09/22 职场文书
乡镇党员干部群众路线对照检查材料思想汇报
2014/09/28 职场文书
四风批评与自我批评发言稿
2014/10/14 职场文书
2015年发展党员工作总结报告
2015/03/31 职场文书
党员干部廉政承诺书
2015/04/28 职场文书
怎样写观后感
2015/06/19 职场文书
企业年会祝酒词
2015/08/11 职场文书
golang判断key是否在map中的代码
2021/04/24 Golang
python中pandas对多列进行分组统计的实现
2021/06/18 Python