变量过滤器
在项目中,访问有些页面时需要带上各种各样的参数。如:显示某个数据列表需要带上分页的参数,这时候需要在控制器里获取这个分页参数值,如果不为数值或者不存在的话,就设置个默认值。
listAction: function(){//获取当前分页数,并转化为数字var page = this.get("page") | 0;//默认在第一页page = page || 1;}
项目中有很多类似分页这样的参数,如果每个都在控制器里写这样的逻辑就非常麻烦。
thinkjs里提供了变量过滤器的功能,通过下面的方式加载Filter。
//加载变量过滤器var filter = thinkRequire("Filter").filter;//通过过滤器来转化分页的值var page = filter(this.get("page"), "page");
支持格式
page过滤分页值,默认为1。thinkjs建议分页值从1开始order数据库排序方式。如:"id DESC","id DESC,name ASC"id转化为数字,默认为0ids将逗号分割的多个id值转化为数组。如:"1,2,3" => [1, 2, 3]in是否在一个范围中,如果不在,返回空字符串strs将逗号格式的多个字符串转化为数组,如:"xx,yy" => ["xx", "yy"]
自动转化
如果在某个操作里调用变量过滤器来过滤也很麻烦,这时候就可以使用thinkjs里的行为功能。
修改App/Conf/tag.js文件,添加如下的代码:
//自定义个行为var filter = thinkRequire("Filter").filter;module.exports = {action_init: [function(http){var types = ["id", "ids", "page", "order"];//对get请求参数进行变量过滤器for(key in http.get){//使用对应的类型转化if(types.indexOf(key) > -1){http.get[key] = filter(http.get[key], key);}else if(/_id$/.test(key)){ //如果参数名是_id结尾的,使用`id`转化http.get[key] = filter(http.get([key], "id"));}}}]}
当然,你可以根据项目里的定义来修改这里的过滤逻辑。 这里统一过滤后,在Action里拿到的参数值就是统一过来后的了。
listAction: function(){//这里拿到的page值是个数值,且默认值为1var page = this.get("page");}
