gpt4 book ai didi

angularjs - AngularJS 处理这样的模态的方式是什么

转载 作者:行者123 更新时间:2023-12-04 01:42:45 25 4
gpt4 key购买 nike

我知道你不应该把你的显示逻辑放在 Controller 中,我正在努力用正确的 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>

Controller :
  ...
$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 值的对象,在用户实际单击“添加小部件”之前不应将其绑定(bind)到我的对象

$scope.myobj 是存储我的数据的地方。

基金会 $("#modalAddWidget").reveal();功能呈现模态叠加。

由于我不应该将显示代码放入 Controller 中,因此解决此问题的正确方法是什么?

最佳答案

您不想从 Controller 操作 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();
}
});

然后在你的 Controller 中:

$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;
};

在你的 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>

基本上你会在你的范围内设置一个 bool 值来显示和隐藏你的模态。 (我不确定是否显示模态的打开/关闭机制,所以我在上面的代码中猜测)。

ALSO:我努力在其中添加一些验证。

关于angularjs - AngularJS 处理这样的模态的方式是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14966981/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com