码迷,mamicode.com
首页 > Web开发 > 详细

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

时间:2015-06-25 06:43:36      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:

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);
  };
});

 

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

标签:

原文地址:http://www.cnblogs.com/Answer1215/p/4599080.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!