express框架的常用语句

express是node的开发框架
文档官网
http://www.expressjs.com.cn/4x/api.html

var express = require("express");

var app = express();

//这里的views指的是提供静态资源的文件夹
app.use(express.static("./views"));

//使用get请求获取并返回数据,如果接收到的url是haha,那么返回haha
app.get("/haha",function(req,res){
		req.send("haha");
});

app.get(/^\/student\/([\d]{10})$/,function(req,res){
	res.send("学生信息,学号" + req.param[0]);
});

//如果要设置渲染的模板引擎,可以通过set方法,事先要下载ejs,然后引用
//app.set("view engine" , "ejs");
//app.get("/",function(req,res){
//拓展名可以省略,默认从views文件夹中找到haha.ejs
//		res.render("haha.ejs",{
		“news”:["我是小菜鸡","我也是小菜鸡","那我是渣渣"]
	});
//}) 


//监听3000端口,用户可以通过3000端口访问
app.listen(3000);

view中的haha.ejs文件

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
</head>
<body>
    <h1>哈哈哈哈</h1>
    <ul>
        <% for(var i = 0 ; i < news.length ; i++){ %>
            <li><%= news[i] %></li>
        <% } %>
    </ul>
</body>
</html>

二、路由
当用get请求访问一个网址的时候,做什么事情:
1app.get(“网址”,function(req,res){
2
3});

当用post访问一个网址的时候,做什么事情:
1app.post(“网址”,function(req,res){
2
3});

如果想处理这个网址的任何method的请求,那么写all
1app.all("/",function(){
2
3});

这里的网址,不分大小写,也就是说,你路由是
1app.get("/AAb",function(req,res){
2 res.send(“你好”);
3});
实际上小写的访问也行。

所有的GET参数,? 后面的都已经被忽略。 锚点#也被忽略
你路由到/a , 实际/a?id=2&sex=nan 也能被处理。

正则表达式可以被使用。正则表达式中,未知部分用圆括号分组,然后可以用req.params[0]、[1]得到。
req.params类数组对象。
1app.get(/^/student/([\d]{10})$/,function(req,res){
2 res.send(“学生信息,学号” + req.params[0]);
3});

冒号是更推荐的写法。
1app.get("/student/:id",function(req,res){
2 var id = req.params[“id”];
3 var reg= /1{6}$/; //正则验证
4 if(reg.test(id)){
5 res.send(id);
6 }else{
7 res.send(“请检查格式”);
8 }
9});

表单可以自己提交到自己上。
1app.get("/",function(req,res){
2 res.render(“form”);
3});
4
5app.post("/",function(req,res){
6 //将数据添加进入数据库
7 res.send(“成功”);
8});

适合进行 RESTful路由设计。简单说,就是一个路径,但是http method不同,对这个页面的使用也不同。
/student/345345

get 读取学生信息
add 添加学生信息
delete 删除学生新

三、中间件
如果我的的get、post回调函数中,没有next参数,那么就匹配上第一个路由,就不会往下匹配了。
如果想往下匹配的话,那么需要写next()
1app.get("/",function(req,res,next){
2 console.log(“1”);
3 next();
4});
5
6app.get("/",function(req,res){
7 console.log(“2”);
8});

下面两个路由,感觉没有关系:
1app.get("/:username/:id",function(req,res){
2 console.log(“1”);
3 res.send(“用户信息” + req.params.username);
4});
5
6app.get("/admin/login",function(req,res){
7 console.log(“2”);
8 res.send(“管理员登录”);
9});
但是实际上冲突了,因为admin可以当做用户名 login可以当做id。

解决方法1:交换位置。 也就是说,express中所有的路由(中间件)的顺序至关重要。
匹配上第一个,就不会往下匹配了。 具体的往上写,抽象的往下写。
1app.get("/admin/login",function(req,res){
2 console.log(“2”);
3 res.send(“管理员登录”);
4});
5
6app.get("/:username/:id",function(req,res){
7 console.log(“1”);
8 res.send(“用户信息” + req.params.username);
9});

解决方法2:
1app.get("/:username/:id",function(req,res,next){
2 var username = req.params.username;
3 //检索数据库,如果username不存在,那么next()
4 if(检索数据库){
5 console.log(“1”);
6 res.send(“用户信息”);
7 }else{
8 next();
9 }
10});
11
12app.get("/admin/login",function(req,res){
13 console.log(“2”);
14 res.send(“管理员登录”);
15});

路由get、post这些东西,就是中间件,中间件讲究顺序,匹配上第一个之后,就不会往后匹配了。next函数才能够继续往后匹配。

app.use()也是一个中间件。与get、post不同的是,他的网址不是精确匹配的。而是能够有小文件夹拓展的。
比如网址: http://127.0.0.1:3000/admin/aa/bb/cc/dd
1app.use("/admin",function(req,res){
2 res.write(req.originalUrl + “\n”); // /admin/aa/bb/cc/dd
3 res.write(req.baseUrl + “\n”); // /admin
4 res.write(req.path + “\n”); // /aa/bb/cc/dd
5 res.end(“你好”);
6});

如果写一个/
1//当你不写路径的时候,实际上就相当于"/",就是所有网址
2app.use(function(req,res,next){
3 console.log(new Date());
4 next();
5});

app.use()就给了我们增加一些特定功能的便利场所。
实际上app.use()的东西,基本上都从第三方能得到。

● 大多数情况下,渲染内容用res.render(),将会根据views中的模板文件进行渲染。如果不想使用views文件夹,想自己设置文件夹名字,那么app.set(“views”,“aaaa”);
● 如果想写一个快速测试页,当然可以使用res.send()。这个函数将根据内容,自动帮我们设置了Content-Type头部和200状态码。send()只能用一次,和end一样。和end不一样在哪里?能够自动设置MIME类型。
● 如果想使用不同的状态码,可以:
res.status(404).send(‘Sorry, we cannot find that!’);
● 如果想使用不同的Content-Type,可以:
res.set(‘Content-Type’, ‘text/html’);

四、GET请求和POST请求的参数
● GET请求的参数在URL中,在原生Node中,需要使用url模块来识别参数字符串。在Express中,不需要使用url模块了。可以直接使用req.query对象。
● POST请求在express中不能直接获得,必须使用body-parser模块。使用后,将可以用req.body得到参数。但是如果表单中含有文件上传,那么还是需要使用formidable模块。

Node中全是回调函数,所以我们自己封装的函数,里面如果有异步的方法,比如I/O,那么就要用回调函数的方法封装。

错误:
1res.reder(“index”,{
2 “name” : student.getDetailById(234234).name
3});
4
5

正确:
6
7student.getDetailByXueHao(234234,function(detail){
8 res.render(“index”,{
9 “name” : detail.name
10 })
11});
12
1


  1. \d ↩︎

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值