我知道你不应该把你的显示逻辑放在一个控制器中,我正在努力用正确的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>
Run Code Online (Sandbox Code Playgroud)
控制器:
...
$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');
}
...
Run Code Online (Sandbox Code Playgroud)
注意:$ scope.ui是我用来存储不应绑定到我的对象的UI值的对象,直到用户实际点击"添加窗口小部件"为止
$ scope.myobj是我的数据存储位置.
Foundation的$("#modalAddWidget").reveal();功能提供了模态叠加.
因为我不应该将我的显示代码放在控制器中,所以采用这种方法的正确方法是什么?
Ben*_*esh 21
您不希望从控制器操纵DOM(甚至引用它).
这里的指令最好.
app.directive('revealModal', function (){
return function(scope, elem, attrs) {
scope.$watch(attrs.revealModal, function(val) {
if(val) {
elem.trigger('reveal:open');
} else {
elem.trigger('reveal:close');
}
});
elem.reveal();
}
});
Run Code Online (Sandbox Code Playgroud)
然后在你的控制器中:
$scope.modalAddWidget = function (){
$scope.ui = { add_widget_value: '' };
$scope.showModal = true;
};
$scope.addWidget = function (){
$scope.myobject.widgets.push({"name": $scope.ui.add_widget_value});
$scope.ui.add_widget_value = '';
$scope.showModal = true;
};
Run Code Online (Sandbox Code Playgroud)
并在您的HTML中
<div class="button" ng-click="modalAddWidget()">Add Widget</div>
<div id="modalAddWidget" class="reveal-modal" reveal-modal="showModal">
<h6>New Widget</h6>
<form name="addWidgetForm" ng-submit="addWidget()">
<fieldset>
<legend>Widget Name</legend>
<input type="text" name="widgetValue" ng-model="ui.add_widget_value" required />
<span ng-show="addWidgetForm.widgetValue.$error.required">required</span>
</fieldset>
<button type="submit" class="small button right">Add Widget</button>
<div class="small button right secondary" ng-click="showModal = false;">Cancel</div>
</form>
</div>
Run Code Online (Sandbox Code Playgroud)
基本上你在你的范围内设置一个布尔值来显示和隐藏你的模态.(我不确定揭示模态的打开/关闭机制,所以我猜测上面的代码).
另外:我在那里添加了一些验证.