问题描述
我们在 cshtml 页面中输入了类型编号。它在表单验证时在 chrome 中工作正常。 但是在 Internet Explorer (IE) 中,它在数字字段中接受逗号 (,) 并将其与逗号一起保存。 请建议。
cshtml 代码:
@Html.TextBoxFor(m => m.xxx,null,new { @class = "form-control",@required = "required",@type = "number",@step = "0.01",@id = "xxx" })
IE 截图:
在 IE 中,我们可以输入逗号并接受它的值。
Chrome 屏幕截图:
这里不允许输入逗号。
在 IE 中我也不想要逗号。这有什么限制吗?
解决方法
您可以尝试使用表单验证。并使用如下所示的输入(不使用@Html.TextBoxFor)。我有一个模型,它有一个属性 Id,这里是一个演示:
查看:
<form id="myform" method="post">
<input name="Id" type="number" step="0.01" class = "form-control"/>
<input type="submit" value="submit" />
</form>
js:
<script src="~/lib/jquery-validation/dist/jquery.validate.min.js"></script>
<script src="~/lib/jquery-validation-unobtrusive/jquery.validate.unobtrusive.min.js"></script>
<script>
$(function () {
$("#myform").validate({
rules: {
Id: {
required:true,doubles: true
},},messages: {
Id: {
//doubles: "You can only enter numbers and dot"
},}
})
})
$.validator.addMethod("doubles",function (value,element,params) {
var doubles = /^[0-9]*([.][0-9]{1,2})?$/;
return this.optional(element) || (doubles.test(value));
},"You can only enter numbers and dot");
</script>