一、安装express

cnpm || npm  install express --save ;

1. Hello  World

var express = require('express');

var app = express();

app.get('/',function(req,res){
res.send('hello world');
}); var server = app.listen('3000',function(){
var host = server.address().address;
var port = server.address().port; console.log('server start localhost',host,port);
})

2.express路由

var express = require('express');

var app = express();

//http://localhost:3000/
app.get('/',function(req,res){
res.send('hello world');
});
//http://localhost:3000/user.html
app.get('/user.html',function(req,res){
res.sendFile(__dirname + '/' + 'user.html');
});
//http://localhost:3000/index.html
app.get('/index.html',function(req,res){
res.sendFile(__dirname + '/' + 'index.html')
});
/*
*其实每个路由对于着每个方法,把 req() => 请求的api 看懂
*
* 把 res(); => 的api 看会。就知道怎么和服务端交换啦。
*
* 当客户端发送AJAX请求的时候,其实就是方法的每个方法。
*
*/ var server = app.listen('3000',function(){
var host = server.address().address;
var port = server.address().port; console.log('server start localhost',host,port);
})

3.静态资源 app.user(express.statice('public'));

var express = require('express');

var app = express();

//设置静态资源的位置

app.use(express.static('public'));

//http://localhost:3000/img/1.jpg

//public/img/1.jpg
var server = app.listen('3000',function(){
var host = server.address().address;
var port = server.address().port; console.log('server start localhost',host,port);
})

二、express的中间件

1.应用级中间件

var express = require('express');

var app = express();

// 没有挂载路径的中间件,应用的每个请求都会执行该中间件
app.use(function(req,res,next){ console.log('应用级中间件');
console.log('time' + Date.now());
next();
}) app.get('/',function(req,res){
res.send('我是 根路径')
}); // 挂载至 /user/:id 的中间件,任何指向 /user/:id 的请求都会执行它
app.get('/user/:id',function(req,res,next){
console.log('我是 user路由上面的子中间件'); next();
});
app.get('/user/:id',function(req,res){
var id = req.params.id; res.send(id);
}); app.get('/method/:id',function(req,res,next){
console.log('methos路径的参数',req.params); next();
},function(req,res,next){
console.log('methods路径的第二个参数',req.method)
next();
}) app.get('/method/:id',function(req,res){
var path = req.route; res.send(path);
});
var server = app.listen('3000',function(){
var host = server.address().address;
var port = server.address().port;
console.log('server start localhost',host,port);
})

2.路由级中间件 express.Router();

var express = require('express');
var router = express.Router();
var app = express(); router.use(function(req,res,next){
console.log(req.path);
next()
}); router.get('/user/:id',function(req,res,next){
console.log(req.originalUrl);
next();
}) router.get('/user/:id',function(req,res){
res.send(req.params);
})
app.use('/',router)
var server = app.listen('8080',function(){
console.log('start')
});

3.错误级中间件

var express = require('express');
var app = express(); app.use(function(error,req,res,next){
res.status('500').send('something error');
}) var server = app.listen('3000',function(){
console.log('server start');
})

4.静态资源中间件 express.static();

三、模板引擎

1.安装jade模板引擎,cnpm || npm install jade --save

var express = require('express');
var app = express(); app.set('views','./views');
app.set('view engine','jade'); app.get('/',function(req,res){
res.render('index',{title:'jade',message:'模板引擎'})
}); var server = app.listen('3000',function(req,res){
console.log('server start');
})

2.view 下面的index.jade

html
head
title!= title
body
h1!= message

express入门学习(一)的更多相关文章

  1. 1.Express入门

    Express提供了轻量级框架,把Node.js的http模块功能封装在接口中. 也扩展了http模块功能,处理服务器路由,响应,cookie和HTTP请求的状态. 实现Express充当服务器,设计 ...

  2. cocos2d-x入门学习笔记,主要介绍cocos2d-x的基本结构,并且介绍引擎自带的示例

    cocos2d-x 3.0 制作横版格斗游戏 http://philon.cn/post/cocos2d-x-3.0-zhi-zuo-heng-ban-ge-dou-you-xi http://blo ...

  3. node.js Web应用框架Express入门指南

    node.js Web应用框架Express入门指南 作者: 字体:[增加 减小] 类型:转载 时间:2014-05-28 我要评论 这篇文章主要介绍了node.js Web应用框架Express入门 ...

  4. vue入门学习(基础篇)

    vue入门学习总结: vue的一个组件包括三部分:template.style.script. vue的数据在data中定义使用. 数据渲染指令:v-text.v-html.{{}}. 隐藏未编译的标 ...

  5. Hadoop入门学习笔记---part4

    紧接着<Hadoop入门学习笔记---part3>中的继续了解如何用java在程序中操作HDFS. 众所周知,对文件的操作无非是创建,查看,下载,删除.下面我们就开始应用java程序进行操 ...

  6. Hadoop入门学习笔记---part3

    2015年元旦,好好学习,天天向上.良好的开端是成功的一半,任何学习都不能中断,只有坚持才会出结果.继续学习Hadoop.冰冻三尺,非一日之寒! 经过Hadoop的伪分布集群环境的搭建,基本对Hado ...

  7. PyQt4入门学习笔记(三)

    # PyQt4入门学习笔记(三) PyQt4内的布局 布局方式是我们控制我们的GUI页面内各个控件的排放位置的.我们可以通过两种基本方式来控制: 1.绝对位置 2.layout类 绝对位置 这种方式要 ...

  8. PyQt4入门学习笔记(一)

    PyQt4入门学习笔记(一) 一直没有找到什么好的pyqt4的教程,偶然在google上搜到一篇不错的入门文档,翻译过来,留以后再复习. 原始链接如下: http://zetcode.com/gui/ ...

  9. Hadoop入门学习笔记---part2

    在<Hadoop入门学习笔记---part1>中感觉自己虽然总结的比较详细,但是始终感觉有点凌乱.不够系统化,不够简洁.经过自己的推敲和总结,现在在此处概括性的总结一下,认为在准备搭建ha ...

随机推荐

  1. 大神教你零基础学PS,30堂课从入门到精通

    ps视频教程,ps自学视频教程.ps免费视频教程下载,大神教你零基础学PS教程视频内容较大,分为俩部分: 大神教你零基础学PS--30堂课从入门到精通第一部分:百度网盘,https://pan.bai ...

  2. 火狐浏览器油猴子GreaseMonkey使用教程

    火狐浏览器油猴子GreaseMonkey使用教程 首先下载火狐浏览器 安装成功后用火狐浏览器打开链接,界面如下 然后搜索GreaseMonkey. 搜索结果,图标是个小猴子,然后添加到火狐浏览器,成功 ...

  3. Android Library和Android APP、Java Library的区别

    Android Library和Android APP.Java Library的区别 Android Library在目录结构上与Android App相同,它能包含构建APP所需的一切(如源代码. ...

  4. jmeter线程组介绍

    Jmeter中的测试计划是一直有的,但可以在右侧修改名字,要开始做具体测试设计前,都需要在测试计划下边添加一个线程组,添加路径为鼠标捕获测试计划后,点击鼠标右键->添加->Threads( ...

  5. SICP读书笔记 2.2

    SICP CONCLUSION 让我们举起杯,祝福那些将他们的思想镶嵌在重重括号之间的Lisp程序员 ! 祝我能够突破层层代码,找到住在里计算机的神灵! 目录 1. 构造过程抽象 2. 构造数据抽象 ...

  6. Python 利用 BeautifulSoup 爬取网站获取新闻流

    0. 引言 介绍下 Python 用 Beautiful Soup 周期性爬取 xxx 网站获取新闻流: 图 1 项目介绍 1. 开发环境 Python: 3.6.3 BeautifulSoup:   ...

  7. Windows下的ROUGE文本测评工具基本安装

    需要的安装包: rouge1.5.5:https://pan.baidu.com/s/1B7-LYn1lZKC8f51yXxNK9w Strawberry Perl :http://strawberr ...

  8. 02_python内置模块_timeit

    timeit模块可以用来测试一小段python代码的执行速度. (1)timeit.Timer(stmt='pass', setup='pass', timer=<timer function& ...

  9. 【Coursera-ML-Notes】线性回归(上)

    什么是机器学习 关于机器学习,有以下两种不同的定义. 机器学习是研究如何使电脑具备学习能力,而不用显式编程告诉它该怎么做. the field of study that gives computer ...

  10. [Github] Github使用教程

    前言 Github是一个面向开源及私有软件项目的托管平台.它可以免费使用,并且速度快速,拥有超多的用户.是目前管理软件开发和发现已有代码的首选平台.下面将向Github新手介绍相关操作. 正文 注册 ...