asp.net mvc 设置数字格式默认十进制千位分隔符

Posted

技术标签:

【中文标题】asp.net mvc 设置数字格式默认十进制千位分隔符【英文标题】:asp.net mvc set number format default decimal thousands separators 【发布时间】:2012-10-26 11:56:25 【问题描述】:

如何在 asp.net mvc 中设置默认的十进制和千位分隔符来格式化数字而不考虑文化?

【问题讨论】:

【参考方案1】:

您可以创建一个DisplayTemplate 来处理此类数字在您的视图中的显示方式:

/Views/Shared/DisplayTemplates/float.cshmtl:

@model float
@string.Format("0:N2", Model);

如果Amount 的类型是float,那么你可以从你的观点中这样称呼它:

@html.DisplayFor(m => m.Amount)

【讨论】:

那么这个模板是怎么引用的呢?【参考方案2】:

要控制千位分隔符,您必须将更改应用于当前区域性的 NumberFormat

如果您希望无论当前文化如何都发生这种情况,您可以简单地克隆当前文化,应用您修改后的 NumberFormat 并将其设置为当前文化。

在 MVC 应用程序中,您通常会在 Application_BeginRequest 期间执行此操作

protected void Application_BeginRequest(object sender, EventArgs e)

    newCulture = (CultureInfo)CultureInfo.CurrentCulture.Clone();
    newCulture.NumberFormat.NumberGroupSeparator = "~";

    System.Threading.Thread.CurrentThread.CurrentCulture = newCulture;
    System.Threading.Thread.CurrentThread.CurrentUICulture = newCulture;

现在您可以使用 ToString() 的“普通”格式选项来根据您的需要进一步控制格式:

var a = 3000.5;
var s = a.ToString('N:2') // 3~000.50
s = a.ToString('N:4') // 3~000.5000

【讨论】:

更新 System.Threading.Thread.CurrentThread.CurrentCulture 不起作用,因为它导致了其他错误。我可以举个例子:当我尝试在 Number 中转换默认格式的字符串(例如“14543.12”)时,它会抛出错误。这是有道理的。无论如何,谢谢你的帮助【参考方案3】:

您需要指定自定义数字格式才能实现您要查找的内容。 Here is the MSDN 关于创建自定义字符串格式化函数。

如果您确实需要自定义千位分隔符,请创建您自己的 NumberFormatInfo 变量,将您想要的值分配给千位分隔符(如果需要,还可以使用小数)。然后将自定义格式应用于您的号码。

var numberFormatter = new CultureInfo( "en-US", false ).NumberFormat;
numberFormat.NumberDecimalSeparator = ";";
numberFormat.NumberGroupSeparator = "-";
var myNumber = 1234567.89;
var myFormattedNumber = myNumber.ToString("#,###.##", numberFormatter);

//myFormattedNumber -> 1-234-567;89

关于NumberFormat class from the MSDN的一些信息

【讨论】:

【参考方案4】:

variable.ToString("n2") - 这在 ASP.Net MVC Razor 中对我有用。

【讨论】:

【参考方案5】:
string.Format("0:N2", yourLovelyNumber);

【讨论】:

好的,但是我希望能够自己指定小数和千位分隔符,我该怎么做?【参考方案6】:

我将发布最终对我有用的代码。在控制器上,在 OnActionExecuting 函数上:

ViewBag.CurrentNumberFormat = new System.Globalization.CultureInfo("en-US", false).NumberFormat;
ViewBag.CurrentNumberFormat.NumberDecimalDigits = 2;
ViewBag.CurrentNumberFormat.NumberDecimalSeparator = "~";
ViewBag.CurrentNumberFormat.NumberGroupSeparator = " ";

在视图中:

 @((1234567.435).ToString("#,###.##", ViewBag.CurrentNumberFormat))

【讨论】:

这与我在下面发布的内容有何不同 :( 很高兴你成功了! 这是不同的,因为每当我需要格式化一个数字时,我不必编写 5 行代码而不是 1 行。您的帖子确实很有帮助和鼓舞人心,谢谢【参考方案7】:

我有同样的问题,可以推荐 autoNumeric 插件https://github.com/autoNumeric/autoNumeric

包含插件:

<script src="~/Scripts/autoNumeric/autoNumeric.min.js" type="text/javascript"></script>

HTML:

 <input type="text" id="DEMO" data-a-sign="" data-a-dec="," data-a-sep="." class="form-control"> 

脚本:

<script>
 jQuery(function($) 
$('#DEMO').autoNumeric('init');   
 );
</script>

您只能输入数字,如果输入 100000,99,您将看到 100.000,99。

【讨论】:

截至今天,在当前稳定版本4 中不再支持旧的 jQuery 表示法。这行不通。只需使用 new AutoNumeric('#DEMO') 就可以了!

以上是关于asp.net mvc 设置数字格式默认十进制千位分隔符的主要内容,如果未能解决你的问题,请参考以下文章

检测 VB.Net 中数字的文化,即小数点/千位分隔符的句点或逗号

在 ASP.NET MVC 中设置默认 JSON 序列化程序

千位欧美十进制格式

在Textview中显示千位分隔符和十进制格式的数字

mySQL格式数字输出,千位分隔符

asp.net mvc 在哪里设置默认文化?