- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我试图找到一种方法,在初始页面加载时以百分比(例如 97,52%)显示 html 输入字段(通过 Angular 服务获取到后端的数据,即可观察/订阅),但也有这个输入字段松散它是我编辑时的百分比格式(即,当引发 DOM(焦点)事件时)。
format 的数据绑定(bind)到一个模型。让我们将模型字段称为 myModel.percentNumber,其中对于 '100 %' 为 percentNumber=1(对于 '69 %' 为 .69,或者对于 '10 000 %' 为 100)
因此,当我单击指示“97,52 %”的字段时,我希望它变为“97.52”,但模型中的数据绑定(bind)值应为 0.9752,因为这是我需要存储的。
该字段应该使用 ngModel 进行绑定(bind)。
备注 :这应该适用于国际化,所以我不能使用基于删除空格、替换 '.' 的“肮脏”解决方案。经过 ',' ...
在这里你可以看到我举了一个例子,其中格式化的百分比值应该有一个逗号作为小数分隔符和一个空格作为千位分隔符,但这取决于用户的本地化。
到目前为止,我已经尝试了一些东西,但没有一个解决了所有问题。
1) 使用 2 路绑定(bind) 作为起点,即<input [(ngmodel)]="myModel.percentNumber | percent:'1.2-2'">
...但它确实会导致管道出现问题:
Uncaught Error: Template parse errors:
<input [ngmodel]="myModel.percentNumber | percent:'1.2-2'" (ngModelChange)="myModel.percentNumber = $event">
PercentFormatterDirective
带选择器
percentFormatter
和一个输入
percentDigits
接受与 PercentPipe 相同格式的字符串类型(即 digitInfo)。一个使用示例是:
<input percentFormatter percentDigits="1.2-2" [ngModel]="myModel.percentNumber" (ngModelChange)="myModel.percentNumber = $event">
1.2-2
两次(即我不想写
<input percentFormatter percentDigits="1.2-2" [ngModel]="myModel.percentNumber | percent:'1.2-2'" (ngModelChange)="myModel.percentNumber = $event">
@HostListener("focus", ["$event.target.value"])
onfocus(value) {
if (value) {
// we have to do the oposite than the transform (e.g. we want to go from % to number)
this.htmlInputElement.value = this.parse(value);
}
}
@HostListener("blur", ["$event.target.value"])
onblur(value) {
if ((value as string).indexOf('%') === -1) {
this.formatNumberInPercent('100for100percent');
}
}
formatNumberInPercent('100for100percent')
的自定义方法将“0.9752”转换为“97,52%”,该方法再次使用 PercentPipe.transform( ) 方法,但没有将值除以 100)...但是,如果我直接在组件中绑定(bind)数据,则此方法有效,ei不使用可观察/订阅。
ngOnInit()
PercentFormatterDirective 的已执行。
ngOnChanges(changes: SimpleChanges)
在 PercentFormatterDirective 中(然后使用
for (let propName in changes)
读取 SimpleChange 数组),但是我没有看到来自 myModel.percentNumber 的新绑定(bind)值。好像
ngOnChanges(changes: SimpleChanges)
只提供一个 SimpleChange 数组,其属性对应于我的指令的输入(即百分比数字)。
private elementRef: ElementRef
注入(inject)指令的构造函数,但正如我在
ngOnChanges()
中所说的我无法获得 myModel.percentNumber 的值(
this.elementRef.nativeElement.value
给了我 ""并且从来没有任何值)。
最佳答案
啊!与#2 如此接近。
您可以在模板中完成这一切。
您可以使用 [value] 设置值作为输入 - 然后使用 (input) - 或可能 (change) 将值转换回。我认为你不能在 ngModel 中使用管道:
<input type="number" [value]="myModel.percentNumber * 100" (input)="myModel.percentNumber = $event.target.value / 100">
关于Angular - 如何以百分比形式制作输入字段格式,但在编辑时删除百分比?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47186115/
我的函数概念上都返回相同的东西,但结果可以采用不同的形式: function GetThingy() 有四个不同的函数,每个可以返回不同的东西: 0.071(代表增长 7.1% 的 float 值)
这个问题在这里已经有了答案: Int division: Why is the result of 1/3 == 0? (19 个回答) 关闭 4 年前。 有什么方法可以计算(例如)120 的 50
我四处寻找这个,它看起来很简单,但我无法让它工作。 我有一张表格,其中一列需要格式化为百分比。下面是我的代码,但它没有格式化单元格,它只是将它们保留为小数。 我想这是因为 cell ,即使声明为范围,
我刚刚开始使用 WPF。从那以后,我开始关注造型系统。我来自 CSS 背景,我想以百分比设置边距。 当前值以像素为单位
我有一个表,其中每一行都有一个描述字段和一个 bool 值。我正在尝试编写一个查询,我可以在其中按每个相应的描述进行分组,并查看 bool 值为真的次数百分比。 示例表: PID Gen
我从文档中发现,考虑到 orientdb 100% 使用磁盘缓存,它使用的最大大小为 70% 用于读取缓存,30% 用于写入缓存 ( http://orientdb.com/docs/last/plo
有什么方法可以获取 docker 容器内部而不是外部的 cpu 百分比吗?! docker stats DOCKER_ID 显示的百分比正是我需要的,但我需要它作为变量。我需要获取容器本身内部的 cp
我正在尝试计算数据集每列中类别的比例(百分比)。 示例数据: df <- data.frame( "Size" = c("Y","N","N","Y","Y"), "Type" =
我应该使用小数还是 float 在数据库中存储比率?特别是在 SQL2005 中。 最佳答案 这取决于您对准确性的需求。如果您可以容忍来自存储 float 的 IEEE 方法的典型错误,则使用 flo
我正在创建一个游戏,目前必须处理一些math.random问题。 我的Lua能力不是那么强,你觉得怎么样 您能制定一个使用 math.random 和给定百分比的算法吗? 我的意思是这样的函数: fu
如何在SQL中动态计算百分比? 假设您有一个名为 Classes 的下表: ClassSession StudentName -------------------------------
如何通过 jQuery 创建具有百分比的数字掩码输入?我是否让输入仅接受三个数字,并在用户完成输入时在数字后添加百分号(keyup)? 我不使用插件。 示例:1% 或 30% 或 99% 或 100%
我正在尝试构建一个工具,可以突出显示具有最高介数中心性的社交网络节点。我将所有网络节点的测量值计算到字典中,按顺序对字典进行排序,然后仅保留前 3 对。 我希望这个工具是可扩展的,所以我想保留前 10
MYSQL 中的人员如何将一个日期条目和分数的用户百分比与另一个日期条目和分数进行比较,从而有效地返回从一个日期到另一个日期的用户百分比增加情况? 几天来我一直在试图解决这个问题,但我已经没有想法了,
我需要进行查询,结果是百分比。 我现在的查询如下所示: select COUNT(CREATE_WEEKDAY), CREATE_WEEKDAY, COUNT(CREATE
我有一个图像上传功能,其工作原理如下: $('.update-insertimage-form').submit(function() { $(".submit-newupdate-btn").add
我的问题很简单,但我仍然找不到这个问题的答案... 假设我们有两个包含图像的容器。 我们有类似的东西 #containera { width: 50%; height: 50%; backgr
是否可以将 CSS 尺寸指定为除其父元素之外的另一个元素的百分比?例如,我想将 div 的 border-radius 指定为 div 宽度的 10%。但是,border-radius: 10% 在
我正在尝试设置按钮的大小并以百分比进行编辑 但是这个的线性大小是不同的。为什么? 最佳答案 您好,问题出在属性 box-sizing 上.默认为 input type
我将它用于我的页眉,该页眉在一页上下滚动页面中发生变化。我注意到它没有响应,所以我想问你是否知道一种使它响应的方法。就像将 0-690 更改为百分比,以便它可以在移动设备和电视屏幕上使用。 HTML
我是一名优秀的程序员,十分优秀!