【发布时间】:2011-12-13 21:52:41
【问题描述】:
我在使用文化、MVC3 和数据注释时遇到问题。我在西班牙数据库(COLLATION is set for LATIN_GENERAL); 上定义了一个表STORES,其中一些字段在SQL 中定义为DECIMAL(18,2) NOT NULL。在我的 MVC3 应用程序中,我已经在 web.config 文件中为“es-ES”设置了文化。另外,我使用的所有视图都是强类型的。
如果我使用 DataAnnotations 进行验证,它会自动添加 Required field 和 The field must be a number 验证。这将是完美的,除了一件事:
The field must be a number 验证迫使我使用点(。)作为小数点分隔符,而不是逗号(,)。所以,我不知道如何更改它,也不知道如何翻译此错误消息。然后我想我可能会强迫用户在 jquery 中使用点而不是逗号(丑陋的解决方案)。所以,我这样做只是为了进行一些测试,结果是它允许我通过验证并在数据库中完美地创建了对象。
但奇怪的是,当我编辑同一个对象时,它显示在我的同一个强类型表单上,用逗号作为小数分隔符而不是点。所以有什么问题?用户永远不能提交对象的版本。
我做错了什么?
- 向数据库添加了正确的排序规则。
- 在 web.config 文件中添加了全球化属性。
- 我什至试过这个MVC 3 jQuery Validation/globalizing of number/decimal field 没有成功...
执行此操作的正确方法是什么?
谢谢
【问题讨论】:
-
问题出现在客户端还是服务器端?即,回发是否在验证错误之前发生?
-
客户端。没有回发。验证错误是javascripted。我认为这与 jquery 如何处理小数分隔符有关。
-
老问题,但这对我有用:stackoverflow.com/questions/5199835/…
标签: asp.net-mvc-3 data-annotations globalization jquery-globalization