- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
目标是当用户单击按钮转到下一页时,如果页面部分填写但无效,则阻止用户继续并显示错误指示符。
在模板驱动的表单中,我有几个容器元素使用 NgModelGroup
属性来表示表单中的“页面”。在我的组件中,我想引用这个集合,以便我可以使用索引访问它们。由于我无法获得此集合(@AJT_82 在下面评论原因),这是我的方法:
我制作了一个类来保存有关页面的信息。
export class Page
{
title: string;
hasError: boolean; //should the page display an error indicator
}
在我的组件中,我在 ngOnInit 中填充了一个数组 pages: Page[]
ngOnInit()
{
this.pages = [{title: "Page 1", hasError: false},
{title: "Page 2", hasError: false},
{title: "Page 3", hasError: false}]
}
@DeborahK 在她的回答中给了我
this.form.form.get('pg1'))
获取名为“pg”+ currentPg+1(+1 以匹配 View ,因为数组从 0 开始)的个人 ngModelGroup
,然后我可以在点击事件中使用它,这将导致A) 转到下一页或 B) 将 hasError
属性设置为 true 并且不转到下一页。
let p = this.form.form.get("pg"+ (this.currentPg+1));
//if the page is partially filled out but not valid
if(p.invalid && p.dirty)
this.pages[this.currentPg].hasError = true;
else
{
//even if it's false, re-false it ;)
this.pages[this.currentPg].hasError = false;
//continue to next page.
//i.e. this.currentPg++ or this.currentPg--
}
回到模板中,为了在选项卡或页面上显示错误指示器,我只检查了 pages[currentPg].hasError
属性。在选项卡元素上分配“has-error”类以设置选项卡样式。
<div id="tabs">
<a *ngFor="let p of pages"
[ngClass]="(p.hasError ? ' has-error' : '')"><p>{{p.title}}</p></a>
</div>
<form #f="ngForm">
<div ngModelGroup="pg1"> <!-- pages[0] -->
<div id="errorBlock" *ngIf="pages[currentPg].hasError">
You had an error.
</div>
<div>
<input ngModel/>
<input ngModel/>
</div>
<div>
<input ngModel/>
<input ngModel/>
</div>
</div>
<div ngModelGroup="pg2"> <!-- pages[1] -->
<input ngModel/>
</div>
</form>
这是示例的组件:
...
currentPg: number = 0;
pages: Page[] = [];
@ViewChild('f') public form: NgForm;
ngOnInit()
{
this.pages = [{title: "Page 1", hasError: false},
{title: "Page 2", hasError: false},
{title: "Page 3", hasError: false}]
}
NextPage()
{
let p = this.form.form.get("pg"+ (this.currentPg+1));
//if the page is partially filled out but not valid
if(p.invalid && p.dirty)
this.pages[this.currentPg].hasError = true;
else
{
//even if it's false, re-false it ;)
this.pages[this.currentPg].hasError = false;
//Do navigation logic.
//i.e. this.currentPg++ or this.currentPg--
}
}
同样,如果有一种方法可以获取 ngModelGroups 的集合并将其用作数组,那么很多问题都可以消失。
最佳答案
这段代码对我有用:
Object.keys((<FormGroup>this.form.form.get('pg1')).controls).forEach(element => {
console.log(element);
});
但关键问题(根据您问题下方的评论)是此代码所在的位置。我将其添加为提交按钮过程的一部分。
在 ngOnInit、ngAfterViewInit 和 ngAfterViewChecked 中,这些元素的值为空/未定义。
如果你只是想知道表单组是否有效,你可以这样做:
let isValid = this.form.form.get('pg1').valid;
或者,您可以使用标签页并在任何有验证错误的页面上显示错误图标,如下所示:
在这个例子中,我使用的是模板驱动的表单。表单上的每个输入元素看起来像这样:
<div class="form-group"
[ngClass]="{'has-error': (productNameVar.touched ||
productNameVar.dirty || product.id !== 0) &&
!productNameVar.valid }">
<label class="col-md-2 control-label"
for="productNameId">Product Name</label>
<div class="col-md-8">
<input class="form-control"
id="productNameId"
type="text"
placeholder="Name (required)"
required
minlength="3"
[(ngModel)] = product.productName
name="productName"
#productNameVar="ngModel" />
<span class="help-block" *ngIf="(productNameVar.touched ||
productNameVar.dirty || product.id !== 0) &&
productNameVar.errors">
<span *ngIf="productNameVar.errors.required">
Product name is required.
</span>
<span *ngIf="productNameVar.errors.minlength">
Product name must be at least three characters.
</span>
</span>
</div>
</div>
您可以在此处找到此示例的完整代码:https://github.com/DeborahK/Angular-Routing在 APM-Final 文件夹中。 (这是我的“Angular Routing”Pluralsight 类(class)中的代码。)
关于Angular:迭代 ngForm 控件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45719397/
我想实现自定义搜索,但遇到了一个麻烦。我需要将 UIButton、SearchBar 组合在一个控件中,以便我可以通过指针引用它。然后我将向该组合控件动态添加更多 UIbutton。最重要的是,我想将
它没有在我的方法中执行 if block 中的语句 母版页:- 页面加载事件:- Control c = new Control(); DoSomething(c); 我的方法:- protecte
ComboBox 控件有一个 setConverter 方法,请参阅 JavaFX ComboBox - Display text but return ID on selection举个例子。我正在
我没有找到任何包含用于标记化(标记)文本输入的控件的 wpf 库。也许我找不到库,因为我错误地调用了这个组件。怎么叫或者哪里有这样的库? 最佳答案 DevExpress WPF 库包含多个数据编辑控件
是否有 Silverlight 控件允许您输入文本并将其突出显示为代码? 例如: foreach (client in Clients){ client.Save();} would become
我有以下用户控件 a) Panel.ZIndex="99999999" 是否是将此控件设置为该控件中 TopMost 的正
是否可以在 Windows 窗体中使用 C# 在窗体加载时隐藏所有特定控件,例如标签或按钮,然后选择显示我不想显示的那些? 我有一个包含很多按钮和标签的程序,但我只想在加载时显示一两个,我觉得对每个标
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: Duplicating components at Run-Time 我有一个TMyControl ( Contro
我正在尝试在 Delphi 中编写一个 dll 库,其中包含一个创建 TFrame 后代实例并返回它的函数。但是当我在应用程序中导入这个函数时,每次调用它时,我都会得到一个异常,例如“'xxx'控件没
是否有 Win32 API 调用来确定哪些窗口和/或控件在特定坐标和/或鼠标下可见? 最佳答案 您可以使用GetWindowFromPoint 。它将返回窗口句柄,以便您可以使用 GetClassNa
我需要在编辑控件中输入以下公式: 公式是在 MS Word 中制作的。尝试将其复制/粘贴到编辑控件(单行或多行)后,我得到 M 0.33 Q10T9.1-9.7。 当我输入这个时,我正在研究 Rich
我只是想成功地将它添加到我的窗口中,但这却出奇地困难。 我已经尝试过 #include "windef.h" #include "winbase.h" #include "initguid.h" #i
我希望能够使用 google maps api v3 拥有自己的“街景”按钮。单击按钮时,我希望它根据我的标记经纬度加载街景。然后我希望按钮更改为“返回 map ”,然后再次加载默认 map View
我目前正在用 PHP 开发(另一个)开源 CMS,我想使用 javascript 控件,尤其是管理面板。问题是,是否有任何具有 PHP 接口(interface)的开源、可自由分发的控件(用于创建 j
我为其编写软件的产品之一是会计类应用程序。它用 C++ 编写,使用 C++ Builder 和 VCL 控件,连接到运行在 Linux 上的 PostgreSQL 数据库。 PostgreSQL 数据
我使用 Key Listener 来读取用户的输入,但我遇到了问题。首先,我读到 JTextField“请输入您的姓名”。如果用户输入一个名字,例如 John,它将更改为 John。但是,如果用户输入
我正在尝试对齐数据表列中的复选框(h=center,v=middle) ... 但复选框仍然显示在错误的位置(见附图)
我有一个包含统计信息的 JSON 数据树: { prefix: "a", count: 20, children: [ { prefix: "a:b", c
我在 Photoshop 中设计了一个模型,我打算将它应用到我的产品目录的 ListView 控件中,但它似乎没有正确显示(未对齐?),我希望这里的人可以像我一样指出我的错误试图弄清楚无济于事。 预期
您是使用 ASP.NET 控件还是仅使用带有 CSS 的 HTML? 我在 TextBox 和 DropDownList 的宽度方面遇到了一些问题。在不同的浏览器中,宽度会有所不同,控件的大小也不会相
我是一名优秀的程序员,十分优秀!