表示ロジックをコントローラー内に配置することは想定されていないことを知っています。これにアプローチするための適切な 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();
関数は、モーダル オーバーレイを表示します。
表示コードをコントローラー内に配置するべきではないため、これにアプローチする適切な方法は何ですか?