我知道您不应该将您的显示逻辑放在控制器中,我正在努力使用正确的 AngularJS 方法来解决这个问题。
我在模态框内展示表单。我正在使用 Zurb Foundation 的模态显示。
标记:
<div class="button" ng-click="modalAddWidget">Add Widget</div>
<div id="modalAddWidget" class="reveal-modal">
<h6>New Widget</h6>
<form>
<fieldset>
<legend>Widget Name</legend>
<input type="text" ng-model="ui.add_widget_value" />
</fieldset>
<div class="small button right" ng-click="addWidget()">Add Widget</div>
<div class="small button right secondary" ng-click="addWidgetCancel()">Cancel</div>
</form>
</div>
控制器:
...
$scope.modalAddWidget = function() {
$("#modalAddWidget").reveal();
}
$scope.addWidget = function() {
$scope.myobject.widgets.push({"name": $scope.ui.add_widget_value});
$scope.ui.add_widget_value = '';
$('#modalAddWidget').trigger('reveal:close');
}
$scope.addBudgetCancel = function() {
$scope.ui.add_widget_value = '';
$('#modalAddWidget').trigger('reveal:close');
}
...
注意:$scope.ui 是我用来存储 UI 值的对象,在用户实际单击“添加小部件”之前不应将其绑定到我的对象
$scope.myobj 是存储我的数据的地方。
Foundation 的$("#modalAddWidget").reveal();
功能呈现模态叠加。
由于我不应该将我的显示代码放在控制器中,解决这个问题的正确方法是什么?