所以我有我的 SPA 应用程序。
在 plunker 上(我不会粘贴所有代码,因为它太多了)你可以看到它的部分娱乐(结构和层次结构是相同的)。
问题从哪里开始......根据设计文档,在其中一个页面上,我们有一个指向政策文档的链接和一个供客户检查的复选框,他确实阅读了它。
按设计:
- 复选框始终处于启用状态,因此客户端可以始终尝试检查它
- 客户端打开策略文档后(单击链接),当客户端单击该复选框时,该复选框应变为选中状态
- 如果客户还没有打开(点击)策略文档链接并尝试选中复选框,则在释放鼠标的那一刻它返回未选中,并且应该显示相关的错误消息
更新:
感谢Rafaeelloo和Kobi 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 之后callback
(directive
据我了解)仍然将新值绑定到它。
有没有办法解决这个问题?