在数据表中,我必须将输入验证为货币。当我在删除 $ 符号后输入值时,输入组件会抛出错误。
<p:column>
<f:facet name="header">
<p:outputLabel value="REC REVENUE" />
</f:facet>
<p:inputText id="RERVN" styleClass="RERVN"
value="#{segmentSetup.userSegmentTypesMap['RERVN'].segmentValues[rank].rangeMinValue}"
disabled="#{!segmentSetup.userSegmentTypesMap['RERVN'].selected || (rank==fn:length(segmentSetup.ranks)) }"
validator="#{segmentSetup.validateRanges}">
<f:convertNumber maxFractionDigits="2" minFractionDigits="0" currencySymbol="$" type="currency" />
</p:inputText>
<p:message for="RERVN" />
</p:column>
当我输入不带美元符号的值时,我收到此验证错误。
tabView:segmentRangeTable:0:GRRVN:'45' 无法理解为货币值。示例:$99.99
最佳答案
将 $
与输入分开,并使用普通数字转换器。
$<p:inputText ...>
<f:convertNumber maxFractionDigits="2" minFractionDigits="0" />
</p:inputText>
如有必要,您可以使用 CSS 将 $ 在视觉上重新定位到输入元素中。下面是纯 HTML/CSS 的启动示例:
<div class="currency"><span>$</span><input /></div>
与
.currency span { position: absolute; margin: 5px 2px; }
.currency input { padding-left: 5px; }
关于jsf-2 - 货币转换器可以在未输入时忽略 $ 符号吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14344144/