变量过滤器

在项目中,访问有些页面时需要带上各种各样的参数。如:显示某个数据列表需要带上分页的参数,这时候需要在控制器里获取这个分页参数值,如果不为数值或者不存在的话,就设置个默认值。

  1. listAction: function(){
  2. //获取当前分页数,并转化为数字
  3. var page = this.get("page") | 0;
  4. //默认在第一页
  5. page = page || 1;
  6. }

项目中有很多类似分页这样的参数,如果每个都在控制器里写这样的逻辑就非常麻烦。

thinkjs里提供了变量过滤器的功能,通过下面的方式加载Filter。

  1. //加载变量过滤器
  2. var filter = thinkRequire("Filter").filter;
  3. //通过过滤器来转化分页的值
  4. var page = filter(this.get("page"), "page");

支持格式

  • page 过滤分页值,默认为1。thinkjs建议分页值从1开始
  • order 数据库排序方式。如:"id DESC", "id DESC,name ASC"
  • id 转化为数字,默认为0
  • ids 将逗号分割的多个id值转化为数组。如:"1,2,3" => [1, 2, 3]
  • in 是否在一个范围中,如果不在,返回空字符串
  • strs 将逗号格式的多个字符串转化为数组,如:"xx,yy" => ["xx", "yy"]

自动转化

如果在某个操作里调用变量过滤器来过滤也很麻烦,这时候就可以使用thinkjs里的行为功能。

修改App/Conf/tag.js文件,添加如下的代码:

  1. //自定义个行为
  2. var filter = thinkRequire("Filter").filter;
  3. module.exports = {
  4. action_init: [function(http){
  5. var types = ["id", "ids", "page", "order"];
  6. //对get请求参数进行变量过滤器
  7. for(key in http.get){
  8. //使用对应的类型转化
  9. if(types.indexOf(key) > -1){
  10. http.get[key] = filter(http.get[key], key);
  11. }else if(/_id$/.test(key)){ //如果参数名是_id结尾的,使用`id`转化
  12. http.get[key] = filter(http.get([key], "id"));
  13. }
  14. }
  15. }]
  16. }

当然,你可以根据项目里的定义来修改这里的过滤逻辑。 这里统一过滤后,在Action里拿到的参数值就是统一过来后的了。

  1. listAction: function(){
  2. //这里拿到的page值是个数值,且默认值为1
  3. var page = this.get("page");
  4. }