Node.js express获取参数有三种方法

express获取参数有三种方法:官网介绍如下

  • Checks route params (req.params), ex: /user/:id
  • Checks query string params (req.query), ex: ?id=12
  • Checks urlencoded body params (req.body), ex: id= 

1、例如:127.0.0.1:3000/:index,这种情况下,我们为了得到index,我们可以通过使用req.params得到,通过这种方法我们就可以很好的处理Node中的路由处理问题,同时利用这点可以非常方便的实现MVC模式;

2、例如:127.0.0.1:3000/index?id=12,这种情况下,这种方式是获取客户端get方式传递过来的值,通过使用req.query.id就可以获得,类似于PHP的get方法

3、例如:127.0.0.1:300/index,然后post了一个id=2的值,这种方式是获取客户端post过来的数据可以通过req.body.id获取,类似于PHP的post方法

下面举例介绍下这三个方法:

如下一个test.html代码

  1. <form action="/index" method="get">  
  2.        <input type="text" name="login_name"/>  
  3.      <input type="submit" value="Sign In" />  
  4. </form>  

在nodeJs中我们要自定义HTTP,因此创建index.js

  1. var app = require('express').createServer();  
  2.   
  3. app.get('/:key', function(req, res){  
  4.   console.log(req.params.key);//输出index   
  5.   console.log(req.query.login_name);//输出表单get提交的login_name   
  6.   res.send('great you are right for get method!');//显示页面文字信息   
  7. });  
  8. app.post('/:key', function(req, res){  
  9. <pre name="code" class="javascript">  console.log(req.params.key);//输出index   
  10.   console.log(req.body.login_name);//输出表单post提交的login_name   
  11.   res.send('great you are right for post method!');//显示页面文字信息  

});app.listen(3000);




之后运行node index.js就可以看到本效果,当然前提是你要先访问test.html,至于如何通过express访问一个html文件我就不详细描述了,可以参考如下代码:

  1. global.fs=require('fs');          
  2. var realpath = VIEW + "test.html";  
  3. var file = fs.readFileSync(realpath);  
  4. res.end(file);  

【url.format(urlObject)】

  url.parse(str)的反向操作,输入一个解析过的 URL 对象,返回格式化过的字符串

  urlObject包含了很多字段,比如protocol、slashes、protocol等,且不一定需要全部传,所以有一套解析逻辑

  格式化的工作流程如下

复制代码
href 会被忽略
protocol 无论是否有末尾的 : (冒号),会同样的处理
http, https, ftp, gopher, file 协议会被添加后缀://
mailto, xmpp, aim, sftp, foo, 等协议添加后缀:
slashes 如果协议需要 ://,设置为 true
仅需对之前列出的没有斜杠的协议,比如议 mongodb://localhost:8000/
auth 如果出现将会使用.
hostname 仅在缺少 host 时使用
port 仅在缺少 host 时使用
host 用来替换 hostname 和 port
pathname 无论结尾是否有 / 将会同样处理
search 将会替代 query属性
无论前面是否有 / 将会同样处理
query (对象; 参见 querystring) 如果没有 search,将会使用
hash 无论前面是否有#,都会同样处理
复制代码
复制代码
var url = require('url');
var obj = {
  protocol: 'http:',
  auth: 'user:pass',
  host: 'host.com:8080',
  hash: '#hash',
  query: { author: '小火柴' }
}
//http://user:pass@host.com:8080?author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash
console.log(url.format(obj));
复制代码

【url.resolve(from, to)】

  url.resolve()方法以一种浏览器解析超链接的方式把一个目标URL解析成相对于一个基础URL,参数如下

from <String> 解析时相对的基本 URL。
to <String> 要解析的超链接 URL。
var url = require('url');
console.log(url.resolve('/one/two/three', 'four'));         // '/one/two/four'
console.log(url.resolve('http://example.com/', '/one'));    // 'http://example.com/one'
console.log(url.resolve('http://example.com/one', '/two')); // 'http://example.com/two'
原文地址:https://www.cnblogs.com/IT-LM/p/7026114.html