某一个任务的后续操作一般采用回调函数的形式
var callback = function (error, value) {
if (error) {
return console.log(error);
}
console.log(value);
}
基于nodejs的web开发框架
express框架的核心是对nodejs中http模块的封装。在http模块上加了一个中间层,把http模块生成服务器等代码封装成相应api,直接调用。
中间件是处理http请求的函数,完成各种任务。一个中间件处理完,再传递给下一个中间件。
function uselessMiddleware(req, res, next) {
next();
}
当一个HTTP请求进入服务器,服务器实例会调用第一个中间件(函数),完成后根据设置,决定是否再调用下一个中间件(函数)。
use是express调用中间件的方法,简单说,先匹配路由(可以直接匹配,也可以模式匹配),然后生成一个http服务器,调用一系列函数(又名中间件),完成一些操作。并且可以顺序调用其他中间件。
use方法的一些别名
express.get('admin/update/:id',function(req,res){
var id=req.params.id;
指定变量的值
app.set("views", __dirname + "/views");
app.set("view engine", "jade");
流行的noSQL数据库,专为nodejs开发。首先说明一下,noSQL可不是“not sql”的意思,而是“not only sql”!
用两种方式组织数据以及数据之间的关系:reference和embedded documents。
reference类似于传统数据库模型中的外键,把各个表联系起来。
这种方法就是noSQL数据库的独有部分了。它能在单一的一个文档结构存储相互关联的数据,隐形地储存了这些数据之间的关系。这样做的好处是可以一次查询获取所有数据。而传统的查询需要先通过查询username获取userid,然后在表contact和access通过userid查询对应数据。
假设要存储用户和用户地址,最简单的方法就是用户建一个表,用户地址建一个表。通过名字查询地址时,先查用户表找到用户id,然后通过用户id在地址表里查询地址。
和传统数据库模型不同,noSQL把用户和地址这种对应关系存在一个文档结构中,只需一次查询即可。
当数据关系是一对多时?
同上分析,假设用户有多个地址,可以采用对象数组的方式存在用户表中,一次查询获得所有地址。
根据上面的分析来看,是不是noSQL数据库中只需要一个数据表就能存储所有数据了呢?用传统的思维简直没法想象啊。看看下面的例子。
假设为出版社和图书建表。将出版社直接作为对象加在图书数据表后面。问题是:如果一个出版社出版了多本图书,那么会重复存储多遍出版社的信息,资源浪费。
此时,就可以为出版社也建立一个文档结构,用"reference"联系图书和出版社,如下:
其实还有一个问题,让图书号是出版社的reference,还是出版社是图书的reference?
这要看哪种方式存储的数据量小。如果一个出版社出版的图书数量众多,与其在出版社表里添加图书id,还不如在图书表里添加出版社id。反之亦然。
后续补充。。。