Temporal.PlainDate.prototype.subtract()
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 subtract()
method of Temporal.PlainDate
instances returns a new Temporal.PlainDate
object representing this date moved backward by a given duration (in a form convertible by Temporal.Duration.from()
).
If you want to subtract two dates and get a duration, use since()
or until()
instead.
Syntax
subtract(duration)
subtract(duration, options)
Parameters
duration
-
A string, an object, or a
Temporal.Duration
instance representing a duration to subtract from this date. It is converted to aTemporal.Duration
object using the same algorithm asTemporal.Duration.from()
. options
Optional-
An object containing the following property:
overflow
Optional-
A string specifying the behavior when a date component is out of range. Possible values are:
"constrain"
(default)-
The date component is clamped to the valid range.
"reject"
-
A
RangeError
is thrown if the date component is out of range.
Return value
A new Temporal.PlainDate
object representing the date specified by the original PlainDate
, minus the duration.
Description
Examples
Subtracting a duration
const start = Temporal.PlainDate.from("2022-01-01");
const end = start.subtract({ years: 1, months: 2, weeks: 3, days: 4 });
console.log(end.toString()); // 2020-10-07
For more examples, see add()
.
Specifications
Specification |
---|
Temporal proposal # sec-temporal.plaindate.prototype.subtract |
Browser compatibility
BCD tables only load in the browser