- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试为美元金额(例如 5.00 或 500.00)创建一个文本框,我希望它的工作方式是如果用户输入 5,文本框中的值将显示 0.05,如果用户输入500 文本框中的值将显示 5.00。我目前在文本框上有一个掩码以允许输入 999999.99 以及一个零占位符以显示为 000000.00。我也将 css 方向设置为 rtl,但它无法正常工作。用户仍在输入法线方向,现在一切都正确对齐,这不是我想要的。
我尝试寻找一些解决方案,但运气为零。有没有什么可以实现这种类型的输入?我发现的大部分内容都是为了显示某些语言,例如希伯来语,我只是在寻找一些东西来处理十进制固定值的输入。
这是我的javascript
@section scripts{
<script src="~/Scripts/jquery.maskedinput.js" type="text/javascript"></script>
<script type="text/javascript">
$('form :input:visible:enabled:first').focus();
$('#check_checkAmount').mask('999999.99', { placeholder: "000000.00" });
$('#check_checkAmount').css('direction', 'rtl');
</script>
}
这是我的控件的html
@Html.TextBoxFor(model => model.check.checkAmount, new { @class = "form-control" })
截至目前,如果用户输入 5,它与您在上面看到的代码的工作方式将显示 500000.00 而不是我想要的 000000.05。添加 css direction = rtl 它确实将文本框对齐方式更改为右对齐。我不一定需要文本框右对齐,我只需要能够从右向左输入值即可。
我还尝试了上面相同的代码,但占位符为“”,但也不起作用。如果它有所作为,那将没有多大意义,但值得一试。哈哈。
非常感谢您的帮助。
最佳答案
我找不到任何可以提供我需要的结果的东西,所以我决定编写自己的 javascript 来获得我想要的结果。下面是我的 javascript 代码,我只是将它连接到带有 onkeydown 监听器的文本框。
我的 html 文本框 - 使用 ASP.NET MVC,id 将生成为 check_checkAmount :
@Html.TextBoxFor(model => model.check.checkAmount, new { @class = "form-control" })
下面的 javascript 代码将在每个 keyup 上获取文本框的值并将其拆分为一个数组并逐个字符地检查它是否有效输入,然后相应地对其进行格式化并将其扔回文本框。
window.onload = function () {
prepareEventHandlers();
}
function prepareEventHandlers() {
var regex = /^[0-9]+$/;
var currencyTxt = document.getElementById("check_checkAmount");
currencyTxt.onkeyup = function () {
var amtSplit = currencyTxt.value.split("");
var count = amtSplit.length;
var values = [];
for (var i = 0; i < (count); i++)
{
if (values.length < 1)
{
if (amtSplit[i] != 0 && amtSplit[i].match(regex))
{
values.push(amtSplit[i]);
}
}
else
{
if (amtSplit[i].match(regex))
{
values.push(amtSplit[i]);
}
}
}
var count2 = values.length;
switch(count2)
{
case 0:
currencyTxt.value = '0.00';
break;
case 1:
currencyTxt.value = '0.0' + values[0];
break;
case 2:
currencyTxt.value = '0.' + values[0] + values[1];
break;
case 3:
currencyTxt.value = values[0] + '.' + values[1] + values[2];
break;
case 4:
currencyTxt.value = values[0] + values[1] + '.' + values[2] + values[3];
break;
case 5:
currencyTxt.value = values[0] + values[1] + values[2] + '.' + values[3] + values[4];
break;
case 6:
currencyTxt.value = values[0] + ',' + values[1] + values[2] + values[3] + '.' + values[4] + values[5];
break;
case 7:
currencyTxt.value = values[0] + values[1] + ',' + values[2] + values[3] + values[4] + '.' + values[5] + values[6];
break;
case 8:
currencyTxt.value = values[0] + values[1] + values[2] + ',' + values[3] + values[4] + values[5] + '.' + values[6] + values[7];
break;
default:
currencyTxt.value = values[0] + values[1] + values[2] + ',' + values[3] + values[4] + values[5] + '.' + values[6] + values[7];
break;
}
}
}
您甚至可以添加一些其他监听器,例如 onblur,并确保您的文本框值与正则表达式模式匹配,如下所示:
var regex = /^[0-9]{1,3}[,][0-9]{3}[.][0-9]{2}|[0-9]{1,3}[.][0-9]{2}/;
这将有助于捕获通过鼠标单击进行的任何粘贴,但是我注意到在某些情况下它无法捕获所有失去焦点的情况,因此我的建议和我要做的是在我发回后再次验证我的数据服务器,但上面在我们的文本框中创建自定义输入的 Javascript 部分应该可以减少大多数错误。
关于javascript - 在 asp.net mvc 中使用 RTL 输入的货币/小数输入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41268627/
如何将整数类型转换为 double /浮点类型以显示小数点?例如,如果我想将数字转换为货币格式: 5 会变成 5.004.3 会变成 4.30 javascript 有什么东西可以用来做这种转换吗?
【版权声明】未经博主同意,谢绝转载!(请尊重原创,博主保留追究权) https://www.cnblogs.com/cnb-yuchen/p/18107586 出自【进步*于辰的博客】
我意识到这是一个重复的问题,但是 this 中提到的解决方案这个问题完全不适合我。 我目前的代码如下 Sub ConvertTextToNumber() Dim Area As Range, C As
我正在使用数学 javascript,但在用它来替换点的逗号和逗号的点时遇到了一些麻烦。我可以改变千位分隔符的逗号,但无法设法将小数点变成逗号。我尝试了其他帖子中的一些建议,但没有感到高兴。目标是实现
我正在尝试在 Android 中创建一个数字选择器,但轮子只增加 1。我想增加 0.1。我在网上查了一下,但我发现了一个格式化的浮点数组禁用了轮子。请帮助并为语法感到抱歉,我正在学习。 最佳答案 您可
我正在尝试在多个网站上获取利率。数据相当非结构化,但形式足够接近。我想要捕捉的内容: x.xx% 至 xx.xx% 数据示例: 由 FDIC 成员 WebBank 发放的所有贷款。您的实际利率取决于信
在 MySQL 表中,我有一个具有不同值的 VARCHAR 列,这些值可能代表字符串、整数、浮点、任意值。这些值作为特定于语言的字符串写入数据库,这意味着 123.45 的浮点值可以写为德语中的 "1
我想编写一个正则表达式,它允许整数或具有 0 - 2 个小数位的小数。 有效输入 1 1. 1.1 1.11 111111111 111111111. 111111111.1 111111111.11
我正在尝试为 nullable 实现客户端验证其小数点分隔符可以是逗号(例如:123,45)。 在我看来: ... @Html.LabelFor(model => model.Turnove
我找不到合适的正则表达式来仅从字符串中提取 float 。考虑以下字符串: $string = "8x2.1 3x2"; 我想提取 2.1,我尝试了以下操作,但这给了我整数和 float : preg
我希望使用正则表达式函数分离以下数据,如下所示: 要使用的功能: let fx=(text,regex)=> Web.Page( " var x='
我是 jquery 新手。我有一个带有两个输入框的表单。我实现了一些验证。 Min.Amount Max.Amount
我正在java中实现一个简单的算法,它接受一个整数数组,并查找并返回数组中相邻整数的最大乘积。 为此,我首先初始化了一个名为largestProduct的变量,我用它来跟踪当前找到的最大(最佳)产品。
在 JavaScript 中,我想定义小数点的位置。我只能在示例中真正展示它。 假设输入值为 1234 。 我希望输出为 123.4 。 或者,如果输入是 12345 ,我希望输出是 123.45 。
我有这段代码,只允许在 keypress() 的输入字段中输入数字 if (e.which != 8 && e.which != 0 && (e.which 57)) { return fa
我目前正在开发一些基于 Django 的 Web 项目,在这个 Web 开发过程中,我遇到了以下我无法正确理解的代码。 if price_product['price'] == Decimal('-1
这个问题在这里已经有了答案: How do I print a double value with full precision using cout? (17 个答案) 关闭 7 年前。 我试图在
这应该是微不足道的,但我正在兜圈子,也许有人可以提供帮助。 我有两个表(T1,T2),我希望从中提取每行中的多个值并更新第三个表(T3)的内容当且仅当)T1 中有两个 UQ,NN 字段,T2 匹配,在
如果数字不是十进制,我需要附加.00,但是当我尝试下面的代码时,它会将整个数字更改为0.00。例如,如果数字是12,200,它会将其更改为0.00,而不是在末尾添加.00 $('.total-amou
我正在尝试在容器 View 中设置 9:16 纵横比 View 。以下代码在 viewDidLayoutSubviews 中设置约束,以便在正确的位置考虑自动布局。它还调用 layoutIfNeede
我是一名优秀的程序员,十分优秀!