Temporal.PlainDateTime.prototype.round()
        
        
          Limited availability
        
        
        
          
                
              
                
              
                
              
        
        
      
      This feature is not Baseline because it does not work in some of the most widely-used browsers.
Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.
The round() method of Temporal.PlainDateTime instances returns a new Temporal.PlainDateTime object representing this date-time rounded to the given unit.
Syntax
round(smallestUnit)
round(options)
Parameters
- smallestUnit
- 
A string representing the smallestUnitoption. This is a convenience overload, soround(smallestUnit)is equivalent toround({ smallestUnit }), wheresmallestUnitis a string.
- options
- 
An object containing some or all of the following properties (in the order they are retrieved and validated): - roundingIncrementOptional
- 
A number (truncated to an integer) representing the rounding increment in the given smallestUnit. Defaults to1. For all values ofsmallestUnitexcept"day", the increment must be a divisor of the maximum value of the unit; for example, if the unit is hours, the increment must be a divisor of 24 and must not be 24 itself, which means it can be 1, 2, 3, 4, 6, 8, or 12. For"day", the increment must be 1.
- roundingModeOptional
- 
A string specifying how to round off the fractional part of smallestUnit. SeeIntl.NumberFormat(). Defaults to"halfExpand".
- smallestUnit
- 
A string representing the smallest unit to include in the output. The value must be one of the following: "day","hour","minute","second","millisecond","microsecond","nanosecond", or their plural forms. For units larger than"nanosecond", fractional parts of thesmallestUnitwill be rounded according to theroundingIncrementandroundingModesettings.
 
Return value
A new Temporal.PlainDateTime object representing this date-time rounded to the given unit, where all units smaller than smallestUnit are zeroed out.
Exceptions
- RangeError
- 
Thrown if any of the options is invalid. 
Examples
>Rounding off small units
const dt = Temporal.PlainDateTime.from("2021-07-01T12:34:56.123456789");
const nearestMillisecond = dt.round("millisecond");
console.log(nearestMillisecond.toString()); // 2021-07-01T12:34:56.123
const nearestHalfHour = dt.round({
  smallestUnit: "minute",
  roundingIncrement: 30,
});
console.log(nearestHalfHour.toString()); // 2021-07-01T12:30:00
const nextDay = dt.round({ smallestUnit: "day", roundingMode: "ceil" });
console.log(nextDay.toString()); // 2021-07-02T00:00:00
Specifications
| Specification | 
|---|
| Temporal> # sec-temporal.plaindatetime.prototype.round> | 
Browser compatibility
Loading…