我一直在寻找这个答案,还有一些选择。不幸的是,没有一个对我有意义:(
我正在开发一个电子商务网站,产品价格自动上传“.00”(如果是整数)。我们有一些产品会显示使用的小数(即13.50英镑),但我们只是希望从定价中删除.00的所有实例。
如果有人需要更多相关信息,请告诉我。我知道定价来自网站的许多部分,而不仅仅是一个特定的类。
答案 0 :(得分:13)
如果您 想要删除.00
,如果它是字符串的结尾,那么您可以
str = str.replace(/\.00$/,'');
如果您的.00可能不在字符串的末尾,例如"10.00 $ and 24.00€"
,那么
str = str.replace(/\.00([^\d])/g,'$1');
此处的内容更多是评论:
大多数情况下,数字格式化涉及许多其他要求,我们无法猜测你的是什么。
这是我的一个数字格式化函数的测试集:
// formatFloat(100.0) => "100"
// formatFloat(100.0, 12) => "100"
// formatFloat(100.1) => "100.1"
// formatFloat(100.1, 0) => "100"
// formatFloat(100.7, 0) => "101"
// formatFloat(.0434) => "0.043"
// formatFloat(1.999999) => "2"
// formatFloat(.0000047) => "0"
// formatFloat(.0000047, 6) => "0.000005"
// formatFloat(.0000047, 12) => "0.0000047"
// formatFloat(undefined) => ""
// formatFloat(NaN) => ""
因此,如果您对我给您的解决方案不满意,请花时间确定您的完整要求。
答案 1 :(得分:4)
working demo以下是代码:
var amount=23.00;
if(amount % 1 == 0)
amount=parseInt(amount,10);
答案 2 :(得分:4)
最简单:
Number(1.05) => 1.05
Number(1.00) => 1
Number('1.05') => 1.05
Number('1.00') => 1
OR
parseFloat('102.00 dollar') => 102
parseInt('102.02 dollar') => 102 see it drops .02
parseFloat('102.02 dollar') => 102.02 , but not this
答案 3 :(得分:1)
您可以使用parseFloat:这会将变量推送到一个数字,并且只保留必要的小数
parseFloat('10.50'); // 10.5
parseFloat('10.00'); // 10
parseFloat('99.95000000'); // 95.95
答案 4 :(得分:0)
这可以解决您的问题:
使用parseInt与原始数字进行比较,如果原始数字更大,请保持原样,否则使用parseInt的结果
答案 5 :(得分:0)
这可能是您的解决方案
var result = 13.50;
for (i = 0; i < result.length; i++) {
if (result[i] == '.') {
if (result[i+2] == 0) {
if (result[i+1] == 0) {
result = result.slice(0, -3);
} else {
result = result.slice(0, -1);
}
} else {
result = result;
}
}
}
如果小数点大于2,请使用.toFixed
答案 6 :(得分:0)
只需将数字乘以1
var x = 1.878000 * 1; // becomes 1.878
document.write(x);
document.write("<br>");
var y = 1.656001 * 1; // stays as 1.656001
document.write(y);
答案 7 :(得分:0)
以下解决方案适用于任一侧的货币:
"£12.00".replace(/\.00/g, '') // => "£12"
"12.00€".replace(/\.00/g, '') // => "12€"
"£12.50".replace(/\.00/g, '') // => "£12.50"
在调用replace
之前,请确保您的货币是字符串。您可以使用toFixed(2)
将浮点数转换为字符串(对于带有两位小数的货币):
12.50.toFixed(2) // => "12.50"
答案 8 :(得分:-1)
一种方法是使用number_format(number,decimals,dec_point,thousands_sep)
number_format( 123456.00, 0, ".", "" ); //result 123456
它不是javascript的原生,但是已构建为镜像PHP number_format函数。
http://phpjs.org/functions/number_format/
原则上,从链接获取的代码确实:
function number_format( number, decimals, dec_point, thousands_sep ) {
number = (number + '')
.replace(/[^0-9+\-Ee.]/g, '');
var n = !isFinite(+number) ? 0 : +number,
prec = !isFinite(+decimals) ? 0 : Math.abs(decimals),
sep = (typeof thousands_sep === 'undefined') ? ',' : thousands_sep,
dec = (typeof dec_point === 'undefined') ? '.' : dec_point,
s = '',
toFixedFix = function(n, prec) {
var k = Math.pow(10, prec);
return '' + (Math.round(n * k) / k)
.toFixed(prec);
};
// Fix for IE parseFloat(0.55).toFixed(0) = 0;
s = (prec ? toFixedFix(n, prec) : '' + Math.round(n))
.split('.');
if (s[0].length > 3) {
s[0] = s[0].replace(/\B(?=(?:\d{3})+(?!\d))/g, sep);
}
if ((s[1] || '')
.length < prec) {
s[1] = s[1] || '';
s[1] += new Array(prec - s[1].length + 1)
.join('0');
}
return s.join(dec);
// example 1: number_format(1234.56);
// returns 1: '1,235'
// example 2: number_format(1234.56, 2, ',', ' ');
// returns 2: '1 234,56'
// example 3: number_format(1234.5678, 2, '.', '');
// returns 3: '1234.57'
// example 4: number_format(67, 2, ',', '.');
// returns 4: '67,00'
// example 5: number_format(1000);
// returns 5: '1,000'
// example 6: number_format(67.311, 2);
// returns 6: '67.31'
// example 7: number_format(1000.55, 1);
// returns 7: '1,000.6'
// example 8: number_format(67000, 5, ',', '.');
// returns 8: '67.000,00000'
// example 9: number_format(0.9, 0);
// returns 9: '1'
// example 10: number_format('1.20', 2);
// returns 10: '1.20'
// example 11: number_format('1.20', 4);
// returns 11: '1.2000'
// example 12: number_format('1.2000', 3);
// returns 12: '1.200'
// example 13: number_format('1 000,50', 2, '.', ' ');
// returns 13: '100 050.00'
// example 14: number_format(1e-8, 8, '.', '');
// returns 14: '0.00000001'
}