froum

init

npm install froum
9 downloads in the last week
19 downloads in the last month

计划

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

npm loves you