[AngularJS] Extract predicate methods into filters for ng-if and ng-show

Leaking logic in controllers is not an option, filters are a way to refactor your code and are compatible with ng-if and ng-show.

 

    <div ng-if="main.currentUser | user:'isAdmin'">
      Admin div
    </div>
    <div ng-if="main.currentUser | user:'isntAdmin'">
      Standard user div
    </div>

 

复制代码
var app = angular.module('App', []);

app.controller('MainCtrl', function() {
  var currentUser = { rights: [] };
  function setAdmin(){
    resetAdmin();
    currentUser.rights.push('admin');
  }
  function resetAdmin(){
    currentUser.rights = [];
  }

  this.currentUser = currentUser;
  this.setAdmin    = setAdmin;
  this.resetAdmin  = resetAdmin;
});

app.filter('user', function(){
  var rules = {
    isAdmin: function(user){
      return user.rights.indexOf('admin') !== -1;
    },
    isntAdmin: function(user){
      return !rules.isAdmin(user);
    }
  };
  
  return function(user, rule){
    return rules[rule](user);
  };
});
复制代码

 

posted @   Zhentiw  阅读(238)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
阅读排行:
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· DeepSeek 解答了困扰我五年的技术问题。时代确实变了!
· 本地部署DeepSeek后,没有好看的交互界面怎么行!
· 趁着过年的时候手搓了一个低代码框架
· 推荐一个DeepSeek 大模型的免费 API 项目!兼容OpenAI接口!
点击右上角即可分享
微信分享提示