- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试清除隐藏时的 angularjs 子表单模型值。我有某种用于 ng-if 的条件来隐藏表单的某些部分,并希望如果 ng-if 条件再次返回 true,则表单的该部分没有数据。就这样,这不会那么困难...???
<form name="parentForm">
<input type="text" name="alwaysRequired" ng-model="model.required" required />
<h3>Parent Form</h3>
<input type="checkbox" name="showOptionalFormSelected" ng-model="model.showOptional" id="showOptionalForm" />
<label for="showOptionalForm">show optional form</label>
<div ng-if="model.showOptional" clear-forms-on-hide>
<h3>Optional Form</h3>
<div ng-form="optionalForm">
<input type="text" name="optionalInputName" ng-model="model.optionalValue" required />
</div>
</div>
</form>
我希望它尽可能简单,代码中没有太多指令。
我尝试的一切都不起作用,因为当我试图获取模型绑定(bind)并重置它们时,整个范围树都被破坏了。
对于最后一次尝试,我重建了一个小型的独立示例,以某种方式重现了该问题:
'use strict';
angular.module('clearForm', [])
.component('formBox', {
template: `<div ng-form="{{$ctrl.innerFormName}}"><ng-transclude /></div>`,
transclude: true,
bindings: {
innerFormName: '<'
}
})
.component('inputComponent', {
template: `<input type="text" name="{{$ctrl.inputName}}" ng-model="$ctrl.ngModel" required />`,
transclude: true,
bindings: {
inputName: '<',
ngModel: '='
}
})
.controller('InitModelController', ['$scope', function InitModelController($scope) {
$scope.model = {
optionalValue: 'test',
showOptional: true,
required: 'important something we need',
optional2: {
one: 'one',
other: 'other',
},
componentInput: 'component input'
};
}])
.directive('clearFormsOnHide', function clearFormOnHide() {
return {
restrict: 'A',
priority: 700,
bindings: {
ngIf: '<',
},
link: function(scope, element, attr) {
if (!attr.ngIf)
throw new Error('This directive must be used together with ng-if!');
let formsWatch = null;
let inputsToClear = [];
scope.$watch(attr.ngIf, onIfChange);
function onIfChange(showContent) {
if (!showContent) {
if (formsWatch) formsWatch();
clearKnownInputs();
} else
formsWatch = scope.$watch(attr.clearFormsOnHide, collectNgModelElementsFromForms);
}
function collectNgModelElementsFromForms(formsToClear) {
if (!formsToClear)
throw new Error('No form named ' + attr.clearFormsOnHide + ' found in current scope.', scope);
if (!window.angular.isArray(formsToClear))
formsToClear = [formsToClear];
formsToClear.forEach(collectNgModelsFromForm);
}
function collectNgModelsFromForm(form) {
Object.values(form)
.filter((ele) => ele && ele.hasOwnProperty('$touched'))
.forEach(element => inputsToClear.push(element));
}
function clearKnownInputs() {
inputsToClear.forEach(clearNgModel);
inputsToClear = [];
}
function clearNgModel(hiddenNgModel) {
hiddenNgModel.$rollbackViewValue();
hiddenNgModel.$setViewValue(null);
hiddenNgModel.$commitViewValue();
// eslint-disable-next-line
hiddenNgModel.$$ngModelSet(hiddenNgModel.$$scope, null);
hiddenNgModel.$setUntouched();
hiddenNgModel.$setPristine();
hiddenNgModel.$render();
}
}
};
});
input[type="text"] {
display: block;
}
<script src="//code.angularjs.org/1.6.6/angular.js"></script>
<script src="script.js"></script>
<link href="style.css" rel="stylesheet" type="text/css">
<div ng-app="clearForm" ng-strict-di ng-controller="InitModelController">
<form name="parentForm">
<h3>Parent Form</h3>
<input type="text" name="alwaysRequired" ng-model="model.required" required />
<input type="checkbox" name="showOptionalFormSelected" ng-model="model.showOptional" id="showOptionalForm" />
<label for="showOptionalForm">show optional form</label>
<div ng-if="model.showOptional" clear-forms-on-hide="[parentForm.optionalForm,parentForm.optionalForm2]">
<h3>Optional Form</h3>
<div ng-form="optionalForm2">
<div ng-repeat="name in ['one','other']">
<input type="text" name="optionalForm2_{{name}}" ng-model="model.optional2[name]" required />
</div>
</div>
<div ng-form="optionalForm">
<input type="text" name="optionalInputName" ng-model="model.optionalValue" required />
<input-component input-name="componentInputName" ng-model="model.componentInput"> </input-component>
<label for="showOptionalDateCheckbox">show optional date</label>
<input type="checkbox" name="optionalInputCheckboxName" id="showOptionalDateCheckbox" ng-model="model.optionalCheck" required />
</div>
</div>
<form-box inner-form-name="'boxedOptionalForm'" ng-if="model.optionalCheck" clear-forms-on-hide="[parentForm.boxedOptionalForm]">
<input type="date" name="optionalDate" ng-model="model.optionalDate" />
</form-box>
</form>
<ul>
<li>always required value: {{model.required|json}}</li>
<li>hide optional: {{model.showOptional|json}}</li>
<li>optional 2 value one: {{model.optional2.one|json}}</li>
<li>optional 2 value other: {{model.optional2.other|json}}</li>
<li>optional value: {{model.optionalValue|json}}</li>
<li>optional checkbox: {{model.optionalCheck|json}}</li>
<li>optional component input: {{model.componentInput|json}}</li>
<li>optional date: {{model.optionalDate|json}}</li>
</ul>
</div>
我们几乎所有的事情都使用组件,但这并不会让事情变得更容易:-/
有人知道如何删除一堆模型值而不单独指定它们,但仍然使用 ng-if 吗?如果仅清除表单或仅清除 ng-model 值,这并不重要。
最佳答案
在指令中创建方法 resetModel()
并更改代码:
<input type="checkbox" name="showOptionalFormSelected" ng-model="model.showOptional" id="showOptionalForm" ng-change="resetModel(model)" />
然后在resetModel()方法中重置模型。
关于javascript - 如何清除隐藏时的 Angularjs 子表单模型值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46933770/
我有一个网站,我正在通过学校参加比赛,但我在清除 float 元素方面遇到了问题。 该网站托管在 http://www.serbinprinting.com/corey/development/
我有一个清除按钮,需要使用 JQuery 函数清除该按钮单击时的 TextBox 值(输入的)。 最佳答案 您只需将单击事件附加到按钮即可将输入元素的值设置为空。 $("#clearButton").
我们已经创建了一个保存到 CoreData 然后同步到 CloudKit 的 iOS 应用程序。在测试中,我们还没有找到一种方法来清除应用程序 iCloud 容器中的数据(用于用户私有(private
这是一个普遍的问题,也是我突然想到并且似乎有道理的问题。我看到很多人使用清除div 并且知道这有时不受欢迎,因为它是额外的标记。我最近开始使用 因为它接缝代表了它的实际用途。 当然都引用了:.clea
我有两个单选按钮。如果我检查第一个单选按钮下面的数据将填充在组合框中。之后我将检查另一个单选按钮,我想清除组合框值。 EmployeeTypes _ET = new EmployeeTypes(
我一直在玩 Canvas ,我正在尝试制作一个可以移动和跳跃的正方形,移动部分已经完成,但是跳跃部分有一个问题:每次跳跃时它都会跳得更快 here's a jsfiddle 这是代码: ///////
我该如何在 Dart 上做到这一点? 抓取tbody元素后,我想在其上调用empty(),但这似乎不存在: var el = query('#search_results_tbody'); el.em
我需要创建一个二维模拟,但是在设置新的“框架”时,旧的“框架”不会被清除。 我希望一些圆圈在竞技场中移动,并且每个循环都应删除旧圆圈并生成新圆圈。一切正常,但旧的没有被清除并且仍然可见,这就是我需要改
无论我使用set statusline将状态行更改为什么,我的状态行都不会改变。看起来像 ".vimrc" 39L, 578C
在 WPF 应用程序中,我有一个 ListView 绑定(bind)到我的 ViewModel 上的一个 ObservableCollection。 在应用程序运行期间,我需要删除并重新加载集合中的所
我有一个大型程序,一个带有图形的文本扭曲游戏。在我的代码中的某处,我使用 kbhit() 我执行此代码来清除我的输入缓冲区: while ((c = getchar()) != '\n' && c !
我正在将所有网站的页面加载到主索引页面中,并通过将 href 分成段并在主域名后使用 .hash 函数添加段来更新 URL 显示,如下所示: $('a').click(function(event)
我有一个带有 的表单和 2 控件来保存和重置表单。我正在触发 使用 javascript __doPostBack()函数并在其中传递一个值 __EVENTARGUMENT如果面板应该重置。 我的代
我目前有一堆 UIViewController,每个都是在前一个之上呈现的模式 ViewController。我的问题是我不需要一堆 UIViewController,我只需要最后一个。因此,当出现新
我在一个类中有一些属性方法,我想在某个时候清除这个属性的缓存。 示例: class Test(): def __init__(self): pass @property
在此Test Link我试图将标题和主站点导航安装到博客脚本的顶部。 我清除:两者;在主要网站脚本上工作,但现在把所有东西都扔到了一边。尝试了无数次 fixex 都没有成功!提前感谢 Ant 指点解决
我似乎无法正确清除布局。看this 我无法阻止左栏中的元素向下推右栏中的元素。谁能帮忙? Screenshot with some pointy arrows (死链接) 最佳答案 问题标记/样式似
我希望能够在某个类 (sprite-empos) 之后清除 '' 中的内容,想知道是否有不添加任何新类或不使用 js 的方法(我在下面尝试过不工作)? 为了明确它是“985”,我想在某个视口(view
我想清除ptr_array boost::ptr_array a; ... a.clear(); // missing 如何清理 ptr 容器? 最佳答案 它应该表现得像一个数组,您不能在 C++
这是我使用多 map 制作的一个简单的事件系统;当我使用 CEvents::Add(..) 方法时,它应该插入并进入多重映射。问题是,当我触发这些事件时, multimap 似乎是空的。我确定我没有调
我是一名优秀的程序员,十分优秀!