1

所以我有我的 SPA 应用程序。

在 plunker 上我不会粘贴所有代码,因为它太多了)你可以看到它的部分娱乐(结构和层次结构是相同的)。

问题从哪里开始......根据设计文档,在其中一个页面上,我们有一个指向政策文档的链接和一个供客户检查的复选框,他确实阅读了它。

按设计:

  1. 复选框始终处于启用状态,因此客户端可以始终尝试检查它
  2. 客户端打开策略文档后(单击链接),当客户端单击该复选框时,该复选框应变为选中状态
  3. 如果客户还没有打开(点击)策略文档链接并尝试选中复选框,则在释放鼠标的那一刻它返回未选中,并且应该显示相关的错误消息

更新:

感谢RafaeellooKobi Cohen,我可以大大简化代码,并摆脱手表和无用的东西......

现在这就是我所拥有的......

这是指令控制器:

app.directive('checkBox', [function() {
  var directive = {
    scope: {}, 
    restrict: 'E', 
    controller: function() {},
    controllerAs: 'checkBoxCtrl',
    bindToController: {
      ngModel: '=',
      callback: '&callback',
      text: '@' 
    },
    templateUrl: 'check-box.directive.view.html',
    link: function() {},
    require: 'ngModel'
  };
  return directive;
}]);

和指令html:

<div class="checkboxContainer">
    <label class="btn btn-checkbox" ng-class="{'active': checkBoxCtrl.ngModel}" 
                                    ng-click="checkBoxCtrl.ngModel = !checkBoxCtrl.ngModel; checkBoxCtrl.callback()">
        <span class="checkboxPic"></span> 
        <span class="checkboxText">{{checkBoxCtrl.text}}</span> 
    </label>
</div> 

这是查看html:

<check-box text="check me"  ng-model="viewCtrl.checkBoxResult" 
                            callback="viewCtrl.callback()"></check-box>
<br/>
<a ng-click="viewCtrl.openGoogleClicked = true" href="//www.google.com" target="_blank">Open Google</a>
 
<hr> 

<h3>Status</h3>  
check box result: {{viewCtrl.checkBoxResult}}    
<br/>
google opened: {{viewCtrl.openGoogleClicked}}
<br/>
callback function called: {{viewCtrl.callbackCalled}}

这是视图控制器:

angular.module('app').controller('viewController', ['$scope', function($scope) {
  this.checkBoxResult;
  this.openGoogleClicked;
  this.callbackCalled;
 
  this.callback = function callback() {  
    this.callbackCalled = true;
    if (this.checkBoxResult && angular.isUndefined(this.openGoogleClicked)) {
      this.checkBoxResult = false;
    } 
  };
}]);

question/problem/opened question: 在更改视图控制器Callback之前调用。ngModel因此,如果我将其更改回false内部callback,它并没有真正计量,因为在 a 之后callbackdirective据我了解)仍然将新值绑定到它。

有没有办法解决这个问题?

4

1 回答 1

2

根据您要执行的操作,您可以像此处(此处)一样执行此操作,或者您可以编写具有确定有效性的功能的验证器(这里是编写您自己的验证器的示例),然后您的表单和复选框将包含其中invalid的内容我的意见比不允许用户选中复选框更好

于 2016-04-27T06:19:14.153 回答