express4.x Request对象获得参数方法小谈【原创】
最近看完慕课网 “node.js 建站攻略”后, 对mongodb 操作有了进一步认识, 为了进一步巩固该数据库知识, 于是使用学到的知识搭建一个最简单的mongoDemo.
搭建完成后已放到Github分享, 详情请戳 mongoDemo源码 感兴趣的小伙伴可以看看;回到主题, 完成该小项目后对nodejs后台开发有了一些小悟,本文就req最常用的参数获取做个小结;
node.js后台开发基本都会碰到使用 req.param()、req.params 、 req.query、 req.body获取参数的情况, 那么它们有哪些区别呢?以下详细分析之:
1. req.param()
该方法获得参数最为方便, 可以说是其他三个属性的综合体;但是 express 4.x api文档已写明该方法将会弃用!今后只能改用其他三个req属性获取参数。(Ps: 鄙人express4.x项目使用req.param()时不会报错,但启动项目时会有警告提示)
该方法的使用如下:
// /user/tobi for /user/:name
req.param('name')
// => "tobi"
// ?name=tobi
req.param('name')
// => "tobi" // POST name=tobi
req.param('name')
// => "tobi"
该方法可以获取
1)express路由器传递的参数;
2)地址栏参数;
3)postt提交的参数,例如表单中input的值, ajax(异步)提交的对象值等。
2.req.params
与req.param()方法相比 该属性只能获取 “express路由器传递的参数”, 值得一提的是: 与req.params配合还能在express路由器中玩正则。
先看下简单的req.params 使用:
// GET /user/tj
req.params.name
// => "tj"
完整代码中是这样的:
var express = require('express');
var app = express();
// 地址栏: localhost:3000/user/tj
app.get('/user/:name', function(req, res){
var param = req.params.name
res.send('hello world' + param); // hello world tj
});
然后看看路由器中神奇的正则使用法,在地址栏输入 localhost:3000/file/javascripts/jquery.js , 而路由中设置了 “/file/*” 时:
// GET /file/javascripts/jquery.js
req.params[0]
// => "javascripts/jquery.js"
完整代码:
var express = require('express');
var app = express();
// 地址栏:localhost:3000/file/javascripts/jquery.js
app.get('/file/*', function(req, res){
var param = req.params[0];
res.send(param); //javascripts/jquery.js
});
ps: 如果没在路由器设置参数, 则 req.params 获得的值为空对象 {}
3.req.query
该属性用法最为简单, 直接获取地址栏传递的参数;示例代码如下:
// GET /search?q=tobi+ferret
req.query.q
// => "tobi ferret" // GET /shoes?order=desc&shoe[color]=blue&shoe[type]=converse
req.query.order
// => "desc" req.query.shoe.color
// => "blue" req.query.shoe.type
// => "converse"
完整代码:
var express = require('express');
var app = express(); // 地址栏: localhost:3000/search?q=tobi+ferret
app.get('/search', function(req, res){
var param = req.query.q;
res.send(param); //tobi ferret
}); // 地址栏: localhost:3000/shoes?order=desc&shoe[color]=blue&shoe[type]=converse
app.get('/shoes', function(req, res){
var _order = req.query.order;
var _color = req.query.shoe.color;
var _type = req.query.shoe.type;
console.log(_order); // desc
console.log(_color); // blue
console.log(_type); // converse
res.send('hello world');
});
ps: 如果地址栏没传递参数, req.query获得的值也是空对象{}
4. req.body
该属性主要用与post方法时传递参数使用, 用法最为广泛也最为常见, 例子也比较多(写这部分最累了有木有)。需要说明下的是使用该属性时, 得先确认app.js中有没有导入“body-parser
”, 该模块在express4.x中已经脱离为独立的模块。示例代码如下:
var app = require('express')();
var bodyParser = require('body-parser');
var multer = require('multer'); app.use(bodyParser.json()); // for parsing application/json
app.use(bodyParser.urlencoded({ extended: true })); // for parsing application/x-www-form-urlencoded
app.use(multer()); // for parsing multipart/form-data app.post('/', function (req, res) {
console.log(req.body);
res.json(req.body);
})
最常使用req.body的场合有:
4-1 表单post传递参数至后台:
网站中经常用表单传递参数给后台, 在express4.x中使用req.body接收参数, 完整代码如下:
<form method="POST" action="add" name="userform" >
<input type="text" id="name" name="name" value="xq" class="form-control" />
<input type="text" id="age" name="age" value="12" class="form-control" />
<input type="text" id="job" name="job" value="coder" class="form-control" />
<input type="text" id="hobby" name="hobby" value="run" class="form-control" />
<button type="submit" class="btn btn-primary">提交添加</button>
</form>
var express = require('express');
var router = express.Router(); router.route('/add').post(function(req, res){
var userObj = {};
userObj = {
name: req.body.name,
age: req.body.age,
job: req.body.job,
hobby: req.body.hobby
};
console.log(userObj); // {name:'xq',age:'12',job:'coder',hobby:'run'}
});
4-2 jquery ajax传递参数至后台:
网站开发当然少不了使用异步传递参数给后台, express4.x中也是以req.body接收异步传递的参数, 完整代码如下:
var _id = '123456';
$.post('/user/delete', {id: _id}, function(data){
if (data.error){
$('#removeTips').html('删除异常:' + data.error + ' 请刷新重试。');
}else{
window.location.href = '/admin/';
}
}, 'json');
var express = require('express');
var router = express.Router();
router.route('/user/delete').post(function(req, res){
var _id = req.body.id;
console.log(_id); //
res.json({result: 'success'});
});
ps: 如果post给后台没有传递任何参数时, req.body的值当然也是空对象{}
参考文档:
http://expressjs.com/api.html#request
express4.x Request对象获得参数方法小谈【原创】的更多相关文章
- Request对象获得参数方法:query和body方法
express框架Request对象获得参数方法:query和body方法 req.query 该属性用法很简单,直接获取地址栏传递的参数:例如: //引入依赖 var express = requi ...
- motto - Express 4.x Request对象获得参数方法
本文搜索关键字:motto express node js nodejs javascript request body request.body 1. req.param() 该方法获得参数最为方便 ...
- JAVA-JSP内置对象之request对象的其他方法
相关资料:<21天学通Java Web开发> request对象的其他方法1.request对象除了可以用来获得请求参数,还可以用来获得HTTP标头及其他信息. 方法 ...
- MVC - Request对象的主要方法
MVC - Request对象的主要方法 setAttribute(String name,Object):设置名字为name的request的参数值 getAttribute(String name ...
- Java面试题之Request对象的主要方法
setAttribute(String name,Object):设置名字为name的request的参数值 getAttribute(String name):返回由name指定的属性值 getAt ...
- Request 对象的主要方法
setAttribute(String name,Object):设置名字为 name 的 request 的参数值 getAttribute(String name):返回由 name 指定的属性值 ...
- Request对象的主要方法
setAttribute(String name,Object):设置名字为name的request的參数值 getAttribute(String name):返回由name指定的属性值 getAt ...
- flask中request对象获取参数的方法
从当前request获取内容: method: 起始行,元数据 host: 起始行,元数据 path: 起始行,元数据 environ: 其中的 SERVER_PROTOCOL 是起始行,元数据 he ...
- 一个利用pojo类从前端页面request中获取参数的小框架~
写之前不知道Spring已经实现这样的功能,所以傻傻的写了这个东西! 实现原理挺有趣的在此记录一下.从去年十月参加java开发以来自己终于有了点小进步. 好开心. 解决问题(详解):前端form表单提 ...
随机推荐
- Mysql root 用户密码忘记后重置root密码
[windows] 1.停止mysql服务:打开命令行窗口CMD,Net stop mysql 2.用另外一种方式启动Mysql:在命令行进入到mysql的安装路径下的bin目录下使用 mysqld- ...
- 自动获取 LDAP 基准 DN 列表
问题描述 在使用 LDAP 协议从 Active Directory 等目录管理服务获取组织结构数据时,一般总是需要对目录的检索路径进行配置.但是由于实际使用中的目录组织结构通常会比较复杂,往往会出现 ...
- sql server常用日期格式化
/*8 24 108 - hh:mm:ss */ Select CONVERT(varchar(), GETDATE(), )-- :: Select CONVERT(varchar(), GETDA ...
- java 方法(函数)
所谓方法,就是用来解决一类问题的代码的有序组合,是一个功能模块. 一般情况下,定义一个方法的语法是: 其中: 1. 访问修饰符:方法允许被访问的权限范围, 可以是 public.protected.p ...
- 峰Spring4学习(8)spring对事务的支持
一.事务简介: 二.编程式事务管理: 例子 1.需求:模拟转账,张三向李四转账50元: 数据库中存在t_count表: 代码实现: BankDao.java: package com.cy.dao; ...
- Java缓存相关memcached、redis、guava、Spring Cache的使用
随笔分类 - Java缓存相关 主要记录memcached.redis.guava.Spring Cache的使用 第十二章 redis-cluster搭建(redis-3.2.5) 摘要: redi ...
- LIS系列总结
此篇博客总结常见的LIS模型变形的解法. ------------------------------------------------------------------- 〇.LIS的$O(Nl ...
- 部分流媒体协议及流媒体开发框架vitamio
流媒体协议部分RTP.RTCP.RTSP.MMS.HLS.HTTP progressive streaming 流媒体协议:(RTP.RTCP.RTSP.MMS.HLS.HTTP progress ...
- 按键精灵对VBS的支持
VBSBegin…VBSEnd(VBS块)格式:VBSBegin...VBSEnd用途:可以在VBS块的区域内随意的书写VBS语法指令. 更多说明:由于彻底的转向VBS语言,会导致goto语句不能被兼 ...
- 搜索框请输入关键字 onfocus 和 onblur
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...