以下replace()调用将替换所有尾随0s 和一个尾随.(如果存在):
eval(expression).toPrecision(10).replace(/(?:\.0+|(\.\d+?)0+)$/, "$1")
它是如何工作的?
/(?:\.0+|(\.\d+?)0+)$/在字符串 ( )的末尾查找\.0+或。防止被“捕获”。(\.\d+?)0+$?:\.0+|(\.\d+?)0+
\.0+将匹配.后跟任意数量的0s。
(\.\d+?)0+将匹配.后跟至少一位数字后跟至少一位0. ?确保0+匹配尽可能多的0s。括号“捕获”非0s。
第二个参数 onreplace()是替换匹配内容的新字符串。$1是一个变量,告诉用replace()第一个捕获的值替换匹配的值(因为1在 之后$)。在这种情况下,第一个捕获的值是\.\d+?匹配的。
所以,最后:
.后跟任意数量的0s 将被丢弃
.后跟非0s 后跟0s 将0丢弃 s
例子
有关 、 和 、 和 的精度方法的1比较2,请参见3下文。每组中的第一个(粗体)项目是这种方法。红色项目是那些不符合预期的项目。.40*14*140*1
var tests = [
'.04*1',
'.40*1',
'4*1',
'40*1'
];
var results = {};
for (var i = 0; i < tests.length; i += 1) {
results[i] = {};
for (var p = 1; p < 3; p += 1) {
results[i][p] = {};
results[i][p][0] = {
'output': eval(tests[i]).toPrecision(p).replace(/(?:\.0+|(\.\d+?)0+)$/, "$1"),
'regex': '/(?:\.0+|(\.\d+?)0+)$/, "$1"'
};
results[i][p][1] = {
'output': eval(tests[i]).toPrecision(p).replace(/\.0+$/, ""),
'regex': '/\.0+$/, ""'
};
results[i][p][2] = {
'output': eval(tests[i]).toPrecision(p).replace(/\.([^0]+)0+$/, ".$1"),
'regex': '/\.([^0]+)0+$/, ".$1"'
};
results[i][p][3] = {
'output': eval(tests[i]).toPrecision(p).replace(/0+$/, ""),
'regex': '/0+$/, ""'
};
results[i][p][4] = {
'output': eval(tests[i]).toPrecision(p).replace(/\.?0+$/, ""),
'regex': '/\.?0+$/, ""'
};
}
}
for (var i in results) {
$("#result").append("<h1>" + tests[i] + "</h1>");
for (var p in results[i]) {
var expected = null;
for (var t in results[i][p]) {
var div = $("<div></div>");
if (t == 0) {
expected = results[i][p][t].output;
div.addClass("expected");
} else if (results[i][p][t].output !== expected) {
div.addClass("invalid");
}
div.append("P" + p + ": " + results[i][p][t].output);
div.append(" <small>" + results[i][p][t].regex + "</small>");
$("#result").append(div);
}
$("#result").append("<br>");
}
}
body { font-family: monospace; }
.expected { font-weight: bold; }
.invalid { color: red; }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<div id="result"></div>