德国货币的LocalString方法?

时间:2015-05-05 13:16:34

标签: javascript jquery

var n = (1223578.00).toLocaleString('de-DE');

应该是 - > “1.223.578,00”,但输出为:1.223.578(缺少小数位)

什么错了?

<script type="text/javascript">var amount= '{{currency1}}';</script>

这是来自SQL的填充表格,currency1 = 1223578.00

如何使用此占位符来使用此功能?

1 个答案:

答案 0 :(得分:6)

将minimumFractionDigits属性设置为所需的位数。

var n = (1223578.00).toLocaleString('de-DE',{ minimumFractionDigits: 2 });

产生:1.223.578,00

上述功能可能无法在所有浏览器上使用。要确保在所有浏览器上获得相同的结果,您可以按如下方式手动创建字符串:

修改自:https://stackoverflow.com/a/16157942/4347337

function DelocaleString(x, sep, grp, dec) {
  //add decimals
  var y = x.toFixed(dec);
  //strip decimals
  var x_integer = y.split('.')[0];
  var x_fraction = y.split('.')[1];
  var x_fractionString = "";
  if (dec > 0) {
    x_fractionString = ',' + x_fraction;
  }
  var sx = ('' + x_integer).split('.'),
    s = '',
    i, j;
  sep || (sep = ' '); // default seperator
  grp || grp === 0 || (grp = 3); // default grouping
  i = sx[0].length;
  while (i > grp) {
    j = i - grp;
    s = sep + sx[0].slice(j, i) + s;
    i = j;
  }
  s = sx[0].slice(0, i) + s;
  sx[0] = s;
  return sx.join('.') + x_fractionString
}

示例

$().ready(function() {
  $('#convertBtn').click(function() {
    ConvertNumber();
  });
});

function ConvertNumber() {
  var input = $('#in').val();
  if ($.isNumeric(input)) {
    $('#out').val(DelocaleString(+input, '.', 3, 2));
  } else {
    $('#out').val('Input is not a number!');
  }
}

function DelocaleString(x, sep, grp, dec) {
  //add decimals
  var y = x.toFixed(dec);
  //strip decimals
  var x_integer = y.split('.')[0];
  var x_fraction = y.split('.')[1];
  var x_fractionString = "";
  if (dec > 0) {
    x_fractionString = ',' + x_fraction;
  }
  var sx = ('' + x_integer).split('.'),
    s = '',
    i, j;
  sep || (sep = ' '); // default seperator
  grp || grp === 0 || (grp = 3); // default grouping
  i = sx[0].length;
  while (i > grp) {
    j = i - grp;
    s = sep + sx[0].slice(j, i) + s;
    i = j;
  }
  s = sx[0].slice(0, i) + s;
  sx[0] = s;
  return sx.join('.') + x_fractionString
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" rel="stylesheet" />
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>

<form class="form-horizontal" style="max-width:350px;">
  <div class="form-group">
    <label for="in" class="col-sm-2 control-label">Input</label>
    <div class="col-sm-10">
      <input type="text" class="form-control" id="in" placeholder="Allowable formats: 123.456789, 123456789">
    </div>
  </div>
  <div class="form-group">
    <label for="out" class="col-sm-2 control-label">Output</label>
    <div class="col-sm-10">
      <input type="text" class="form-control" id="out" placeholder="Formatted Number" readonly>
    </div>
  </div>
  <div class="form-group">
    <div class="col-sm-offset-2 col-sm-10">
      <button class="btn btn-default" id="convertBtn">Convert Number</button>
    </div>
  </div>
</form>