froum
v0.0.3
Published
init
Downloads
5
Maintainers
Readme
计划
4月1日晚8点开测 论坛地址:http://jsera.net
测试计划:4月份小范围删档公测,5月、6月不删档公测,7月1日发布beta1.0
论坛模块概念
core
是核心对象,实现了全部论坛功能。通过调用 core.exec / core.call 方法对系统进行操作。
controller控制器
是服务于UI的中间层,介于core核心和UI之间,提供了权限控制、UI所需数据、验证码等。
query查询
是个从数据库或文件系统得到数据的组件,可以自己定制,但必须符合相应接口。
query是core核心层、控制器、UI都可调用的组建,它屏蔽的具体数据库,达到切换各种数据库的接口。
view 动态页
是依赖控制器的。
定义查询组件
查询query,是应用程序与数据库之间的桥梁,用于获取数据。 我们知道查询在任何一个系统中都至关重要,所以要如何发挥其规范性是至关重要的环节; 另外如何能不依赖特定数据库,这个问题也是值得深思,为了做到这一点,我们需要特殊的方式。
定义query
// 第一种查询组件定义方式
var query = require("query-brighthas");
// 添加一个查询
query
.add(
"get a user", // 查询名称
["id",{require:true}], // 限定查询参数, 表示必须要提供一个id,如果不提供会得到一个 callback(null)
function(args,callback){ // 查询函数, 最终返回一个值,只能赋予一个参数。
......
callback(xxx)
})
.add(
"all users",
function(args,callback){
......
callback(xxx)
})
// 其他查询组件定义方式
var query = {
// 第二种方式,args参数没有被限定,需要函数自己处理
"find a user":function(args,callback){
},
// 第三种方式,和第一种方式一样,只不过形式不同而已.
"find a user":{
args:{
"id":{require:true}
},
handle:function(args,handle){
}
},
// 第四种方式,和第一种方式一样,只不过形式不同而已.
"find a user":{
args:["id",{require:true}], // 和第三种参数限制一样,形式不同而已。
handle:function(args,handle){
}
}
}
#### 调用一个查询
// 第一种调用方式
query("get a user",{id:"001"},function(result){
... ...
})
// 第二种调用方式,效果和第一种方式等效,不过形式不同。
// 第二种方式返回一个 promise ,推荐这种调用方式,好处大家都知道。
query("get a user",{id:"001"}).then(function(result){
... ...
})
LICENSE
GPLv3