- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我已经实现了以下组件。它按预期工作和运行。然而,由于 ControlValueAccessor
的实现对我来说是新的,我不得不 follow a blog不了解几个部分的更深层次的细节。所以这是一种“它有效,但为什么?!”的情况。
@Component({ selector: ..., templateUrl: ..., styleUrls: ...,
providers: [{ provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => InputTextComponent),
multi: true }]
})
export class InputComponent implements ControlValueAccessor {
constructor() { }
@Input() info: string;
onChange: any = () => { }
onTouch: any = () => { }
writeValue(input: any): void {
this.info.value = input;
// this.onChange(input);
// this.onTouch();
}
registerOnChange(_: any): void { this.onChange = _; }
registerOnTouched(_: any): void { this.onTouch = _; }
setDisabledState?(state: boolean): void { }
onEdit(value: string): void { this.onChange(value); }
}
当我让它工作时,我注释掉了 writeValue(...)
方法的第二行和第三行,据我所知,没有任何问题。 other blogs 一直建议这些电话同样,所以我确信省略它们是不合适的。但是,我不相信魔法,我更喜欢做事有具体的理由。
为什么在 writeValue(...)< 中执行对
?会出现什么问题,在什么情况下会出现问题?onChange(...)
和 onTouch(...)
的调用很重要
作为支线任务,我也尝试注释掉 the other methods并发现当我删除 setDisabledState(...)
时,我无法分辨任何事情。什么时候可以预期那个会引起问题?它真的需要实现吗(我见过括号前后带有问号的版本,参数如下:setDisabledState?(state: boolean): void { }
但也像这样: setDisabledState(state: boolean)?: void { }
).
最佳答案
阅读这篇详细解释了 ControlValueAccessor
的文章:
如果组件要用作 Angular 表单的一部分,通常需要在组件上实现 ControlValueAccessor
接口(interface)。
I commented out the second and third line of writeValue(...) methodand, as far I can tell, nothing broke.
这可能是因为您没有应用任何表单指令 - formControl
或 ngModel
将 FormControl
链接到您的自定义输入组件。 FormControl
使用 InputComponent
的 writeValue
方法进行通信。
这是我在上面引用的文章中的图片:
writeValue
方法被 formControl
用来设置原生表单控件的值。 registerOnChange
方法被 formControl
用来注册一个回调,每次更新 native 表单控件时都会触发该回调。 registerOnTouched
方法用于指示用户与控件交互。
Why is it important to execute the call to onChange(...) andonTouch(...) in writeValue(...)? What will go wrong and under whatcircumstances can it be expected?
这是一种机制,您实现 ControlValueAccessor
的自定义控件会通知 Angular 的 FormControl
输入中的值已更改或用户与控件进行了交互。
...discovered that I couldn't tell anything going bananas when Iremoved setDisabledState(...)...Does it really need to be implemented?
如界面中所指定,当控件状态更改为“已禁用”或从“已禁用”更改时,表单 API 将调用此函数。根据值,它应该启用或禁用适当的 DOM 元素。如果您希望在关联的 FormControl
状态变为 disabled
时收到通知,则需要实现它,然后您可以执行一些自定义逻辑(例如,禁用输入组件).
关于angular - 为什么在 Angular 中实现 ControlValueAccessor 时需要在 writeValue 中调用 onChange 和 onTouch?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46743218/
我正在尝试用 C 语言编写一个使用 gstreamer 的 GTK+ 应用程序。 GTK+ 需要 gtk_main() 来执行。 gstreamer 需要 g_main_loop_run() 来执行。
我已经使用 apt-get 安装了 opencv。我得到了以下版本的opencv2,它工作正常: rover@rover_pi:/usr/lib/arm-linux-gnueabihf $ pytho
我有一个看起来像这样的 View 层次结构(基于其他答案和 Apple 的使用 UIScrollView 的高级 AutoLayout 指南): ScrollView 所需的2 个步骤是: 为 Scr
我尝试安装 udev。 udev 在 ./configure 期间给我一个错误 --exists: command not found configure: error: pkg-config and
我正在使用 SQLite 3。我有一个表,forums,有 150 行,还有一个表,posts,有大约 440 万行。每个帖子都属于一个论坛。 我想从每个论坛中选择最新帖子的时间戳。如果我使用 SEL
使用 go 和以下包: github.com/julienschmidt/httprouter github.com/shwoodard/jsonapi gopkg.in/mgo.v2/bson
The database仅包含 2 个表: 钱包(100 万行) 事务(1500 万行) CockroachDB 19.2.6 在 3 台 Ubuntu 机器上运行 每个 2vCPU 每个 8GB R
我很难理解为什么在下面的代码中直接调用 std::swap() 会导致编译错误,而使用 std::iter_swap 编译却没有任何错误. 来自 iter_swap() versus swap() -
我有一个非常简单的 SELECT *用 WHERE NOT EXISTS 查询条款。 SELECT * FROM "BMAN_TP3"."TT_SPLDR_55E63A28_59358" SELECT
我试图按部分组织我的 .css 文件,我需要从任何文件访问文件组中的任何类。在 Less 中,我可以毫无问题地创建一个包含所有文件导入的主文件,并且每个文件都导入主文件,但在 Sass 中,我收到一个
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
这个问题在这里已经有了答案: Updating from Rails 4.0 to 4.1 gives sass-rails railties version conflicts (4 个答案) 关
我们有一些使用 Azure DevOps 发布管道部署到的现场服务器。我们已经使用这些发布管道几个月了,没有出现任何问题。今天,我们在下载该项目的工件时开始出现身份验证错误。 部署组中的节点显示在线,
Tip: instead of creating indexes here, run queries in your code – if you're missing any indexes, you
你能解释一下 Elm 下一个声明中的意思吗? (=>) = (,) 我在 Elm architecture tutorial 的例子中找到了它 最佳答案 这是中缀符号。实际上,这定义了一个函数 (=>
我需要一个 .NET 程序集查看器,它可以显示低级详细信息,例如元数据表内容等。 最佳答案 ildasm 是 IL 反汇编程序,具有低级托管元数据 token 信息。安装 Visual Studio
我有两个列表要在 Excel 中进行比较。这是一个很长的列表,我需要一个 excel 函数或 vba 代码来执行此操作。我已经没有想法了,因此转向你: **Old List** A
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
我正在学习 xml 和 xml 处理。我无法很好地理解命名空间的存在。 我了解到命名空间帮助我们在 xml 中分离相同命名的元素。我们不能通过具有相同名称的属性来区分元素吗?为什么命名空间很重要或需要
我搜索了 Azure 文档、各种社区论坛和 google,但没有找到关于需要在公司防火墙上打开哪些端口以允许 Azure 所有组件(blob、sql、compute、bus、publish)的简洁声明
我是一名优秀的程序员,十分优秀!