Math.trunc() function returns the integer part of a number by removing any fractional digits.

The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.

句法

Math.trunc(x)
					

参数

x

A number.

返回值

The integer part of the given number.

描述

Unlike the other three Math 方法: Math.floor() , Math.ceil() and Math.round() , the way Math.trunc() works is very simple. It truncates (cuts off) the dot and the digits to the right of it, no matter whether the argument is a positive or negative number.

The argument passed to this method will be converted to number type implicitly.

因为 trunc() is a static method of Math , you always use it as Math.trunc() , rather than as a method of a Math object you created ( Math is not a constructor).

Polyfill

if (!Math.trunc) {
	Math.trunc = function(v) {
		v = +v;
		if (!isFinite(v)) return v;
		return (v - v % 1)   ||   (v < 0 ? -0 : v === 0 ? v : 0);
		// returns:
		//  0        ->  0
		// -0        -> -0
		//  0.2      ->  0
		// -0.2      -> -0
		//  0.7      ->  0
		// -0.7      -> -0
		//  Infinity ->  Infinity
		// -Infinity -> -Infinity
		//  NaN      ->  NaN
		//  null     ->  0
	};
}
					

or:

if (!Math.trunc) {
	Math.trunc = function (v) {
		return v < 0 ? Math.ceil(v) : Math.floor(v);
	};
}
					

范例

使用 Math.trunc()

Math.trunc(13.37);    // 13
Math.trunc(42.84);    // 42
Math.trunc(0.123);    //  0
Math.trunc(-0.123);   // -0
Math.trunc('-1.123'); // -1
Math.trunc(NaN);      // NaN
Math.trunc('foo');    // NaN
Math.trunc();         // NaN
					

规范

规范
ECMAScript (ECMA-262)
The definition of 'Math.trunc' in that specification.

浏览器兼容性

更新 GitHub 上的兼容性数据
Desktop Mobile Server
Chrome Edge Firefox Internet Explorer Opera Safari Android webview Chrome for Android Firefox for Android Opera for Android Safari on iOS Samsung Internet Node.js
trunc Chrome 38 Edge 12 Firefox 25 IE No Opera 25 Safari 8 WebView Android 38 Chrome Android 38 Firefox Android 25 Opera Android 25 Safari iOS 8 Samsung Internet Android 3.0 nodejs 0.12

图例

完整支持

完整支持

不支持

不支持

另请参阅

元数据

  • 最后修改: