Skip to content

date-manip


date-manip / chain

chain

Interfaces

DateAddingObject

Defined in: dist/types/index.d.ts:1

Extended by

Properties

d?

optional d: number

Defined in: dist/types/index.d.ts:21

day?

optional day: number

Defined in: dist/types/index.d.ts:4

days?

optional days: number

Defined in: dist/types/index.d.ts:12

h?

optional h: number

Defined in: dist/types/index.d.ts:22

hour?

optional hour: number

Defined in: dist/types/index.d.ts:5

hours?

optional hours: number

Defined in: dist/types/index.d.ts:13

m?

optional m: number

Defined in: dist/types/index.d.ts:23

M?

optional M: number

Defined in: dist/types/index.d.ts:20

millisecond?

optional millisecond: number

Defined in: dist/types/index.d.ts:8

milliseconds?

optional milliseconds: number

Defined in: dist/types/index.d.ts:16

minute?

optional minute: number

Defined in: dist/types/index.d.ts:6

minutes?

optional minutes: number

Defined in: dist/types/index.d.ts:14

month?

optional month: number

Defined in: dist/types/index.d.ts:3

months?

optional months: number

Defined in: dist/types/index.d.ts:11

ms?

optional ms: number

Defined in: dist/types/index.d.ts:25

s?

optional s: number

Defined in: dist/types/index.d.ts:24

second?

optional second: number

Defined in: dist/types/index.d.ts:7

seconds?

optional seconds: number

Defined in: dist/types/index.d.ts:15

y?

optional y: number

Defined in: dist/types/index.d.ts:19

Y?

optional Y: number

Defined in: dist/types/index.d.ts:18

year?

optional year: number

Defined in: dist/types/index.d.ts:2

years?

optional years: number

Defined in: dist/types/index.d.ts:10


DateParsingObject

Defined in: dist/types/index.d.ts:39

Extends

Properties

d?

optional d: number

Defined in: dist/types/index.d.ts:21

Inherited from

DateAddingObject.d

day?

optional day: number

Defined in: dist/types/index.d.ts:4

Inherited from

DateAddingObject.day

days?

optional days: number

Defined in: dist/types/index.d.ts:12

Inherited from

DateAddingObject.days

h?

optional h: number

Defined in: dist/types/index.d.ts:22

Inherited from

DateAddingObject.h

hour?

optional hour: number

Defined in: dist/types/index.d.ts:5

Inherited from

DateAddingObject.hour

hours?

optional hours: number

Defined in: dist/types/index.d.ts:13

Inherited from

DateAddingObject.hours

m?

optional m: number

Defined in: dist/types/index.d.ts:23

Inherited from

DateAddingObject.m

M?

optional M: number

Defined in: dist/types/index.d.ts:20

Inherited from

DateAddingObject.M

millisecond?

optional millisecond: number

Defined in: dist/types/index.d.ts:8

Inherited from

DateAddingObject.millisecond

milliseconds?

optional milliseconds: number

Defined in: dist/types/index.d.ts:16

Inherited from

DateAddingObject.milliseconds

minute?

optional minute: number

Defined in: dist/types/index.d.ts:6

Inherited from

DateAddingObject.minute

minutes?

optional minutes: number

Defined in: dist/types/index.d.ts:14

Inherited from

DateAddingObject.minutes

month?

optional month: number

Defined in: dist/types/index.d.ts:3

Inherited from

DateAddingObject.month

months?

optional months: number

Defined in: dist/types/index.d.ts:11

Inherited from

DateAddingObject.months

ms?

optional ms: number

Defined in: dist/types/index.d.ts:25

Inherited from

DateAddingObject.ms

s?

optional s: number

Defined in: dist/types/index.d.ts:24

Inherited from

DateAddingObject.s

second?

optional second: number

Defined in: dist/types/index.d.ts:7

Inherited from

DateAddingObject.second

seconds?

optional seconds: number

Defined in: dist/types/index.d.ts:15

Inherited from

DateAddingObject.seconds

utcOffset?

optional utcOffset: number

Defined in: dist/types/index.d.ts:40

y?

optional y: number

Defined in: dist/types/index.d.ts:19

Inherited from

DateAddingObject.y

Y?

optional Y: number

Defined in: dist/types/index.d.ts:18

Inherited from

DateAddingObject.Y

year?

optional year: number

Defined in: dist/types/index.d.ts:2

Inherited from

DateAddingObject.year

years?

optional years: number

Defined in: dist/types/index.d.ts:10

Inherited from

DateAddingObject.years


IDateChain

Defined in: dist/types/index.d.ts:117

Methods

add()
Call Signature

add(input): this

Defined in: dist/types/index.d.ts:118

Parameters
input

DateAddingObject

Returns

this

Call Signature

add(num, unit): this

Defined in: dist/types/index.d.ts:119

Parameters
num

number

unit

Unit

Returns

this

addDays()

addDays(days): this

Defined in: dist/types/index.d.ts:120

Parameters
days

number

Returns

this

addHours()

addHours(hours): this

Defined in: dist/types/index.d.ts:121

Parameters
hours

number

Returns

this

addMilliseconds()

addMilliseconds(ms): this

Defined in: dist/types/index.d.ts:122

Parameters
ms

number

Returns

this

addMinutes()

addMinutes(minutes): this

Defined in: dist/types/index.d.ts:123

Parameters
minutes

number

Returns

this

addMonths()

addMonths(months): this

Defined in: dist/types/index.d.ts:124

Parameters
months

number

Returns

this

addYears()

addYears(years): this

Defined in: dist/types/index.d.ts:125

Parameters
years

number

Returns

this

clone()

clone(): IDateChain

Defined in: dist/types/index.d.ts:188

Returns

IDateChain

date()
Call Signature

date(date): this

Defined in: dist/types/index.d.ts:164

Parameters
date

number

Returns

this

Call Signature

date(): number

Defined in: dist/types/index.d.ts:165

Returns

number

day()
Call Signature

day(day): this

Defined in: dist/types/index.d.ts:166

Parameters
day

number

Returns

this

Call Signature

day(): number

Defined in: dist/types/index.d.ts:167

Returns

number

dayOfYear()
Call Signature

dayOfYear(): number

Defined in: dist/types/index.d.ts:126

Returns

number

Call Signature

dayOfYear(val): this

Defined in: dist/types/index.d.ts:127

Parameters
val

number

Returns

this

daysInMonth()

daysInMonth(): number

Defined in: dist/types/index.d.ts:128

Returns

number

diff()

diff(input, unit, asFloat?): number

Defined in: dist/types/index.d.ts:129

Parameters
input

ChainInput

unit

Unit

asFloat?

boolean

Returns

number

diffInDays()

diffInDays(input, asFloat?): number

Defined in: dist/types/index.d.ts:130

Parameters
input

ChainInput

asFloat?

boolean

Returns

number

diffInHours()

diffInHours(input, asFloat?): number

Defined in: dist/types/index.d.ts:131

Parameters
input

ChainInput

asFloat?

boolean

Returns

number

diffInMilliseconds()

diffInMilliseconds(input, asFloat?): number

Defined in: dist/types/index.d.ts:132

Parameters
input

ChainInput

asFloat?

boolean

Returns

number

diffInMinutes()

diffInMinutes(input, asFloat?): number

Defined in: dist/types/index.d.ts:133

Parameters
input

ChainInput

asFloat?

boolean

Returns

number

diffInMonths()

diffInMonths(input, asFloat?): number

Defined in: dist/types/index.d.ts:134

Parameters
input

ChainInput

asFloat?

boolean

Returns

number

diffInSeconds()

diffInSeconds(input, asFloat?): number

Defined in: dist/types/index.d.ts:135

Parameters
input

ChainInput

asFloat?

boolean

Returns

number

diffInYears()

diffInYears(input, asFloat?): number

Defined in: dist/types/index.d.ts:136

Parameters
input

ChainInput

asFloat?

boolean

Returns

number

endOf()

endOf(unit): this

Defined in: dist/types/index.d.ts:137

Parameters
unit

Unit

Returns

this

format()

format(formatString?): string

Defined in: dist/types/index.d.ts:138

Parameters
formatString?

string

Returns

string

get()

get(unit): number

Defined in: dist/types/index.d.ts:139

Parameters
unit

Unit

Returns

number

hour()
Call Signature

hour(hour): this

Defined in: dist/types/index.d.ts:168

Parameters
hour

number

Returns

this

Call Signature

hour(): number

Defined in: dist/types/index.d.ts:169

Returns

number

hours()
Call Signature

hours(hours): this

Defined in: dist/types/index.d.ts:179

Parameters
hours

number

Returns

this

Call Signature

hours(): number

Defined in: dist/types/index.d.ts:180

Returns

number

isAfter()

isAfter(input, unit): boolean

Defined in: dist/types/index.d.ts:140

Parameters
input

ChainInput

unit

Unit

Returns

boolean

isBefore()

isBefore(input, unit): boolean

Defined in: dist/types/index.d.ts:141

Parameters
input

ChainInput

unit

Unit

Returns

boolean

isBetween()

isBetween(from, to, unit, inclusivity?): boolean

Defined in: dist/types/index.d.ts:142

Parameters
from

ChainInput

to

ChainInput

unit

Unit

inclusivity?

string

Returns

boolean

isLeapYear()

isLeapYear(): boolean

Defined in: dist/types/index.d.ts:143

Returns

boolean

isSame()

isSame(input, unit): boolean

Defined in: dist/types/index.d.ts:144

Parameters
input

ChainInput

unit

Unit

Returns

boolean

isSameOrAfter()

isSameOrAfter(input, unit): boolean

Defined in: dist/types/index.d.ts:145

Parameters
input

ChainInput

unit

Unit

Returns

boolean

isSameOrBefore()

isSameOrBefore(input, unit): boolean

Defined in: dist/types/index.d.ts:146

Parameters
input

ChainInput

unit

Unit

Returns

boolean

isValid()

isValid(): boolean

Defined in: dist/types/index.d.ts:147

Returns

boolean

millisecond()
Call Signature

millisecond(millisecond): this

Defined in: dist/types/index.d.ts:174

Parameters
millisecond

number

Returns

this

Call Signature

millisecond(): number

Defined in: dist/types/index.d.ts:175

Returns

number

milliseconds()
Call Signature

milliseconds(milliseconds): this

Defined in: dist/types/index.d.ts:185

Parameters
milliseconds

number

Returns

this

Call Signature

milliseconds(): number

Defined in: dist/types/index.d.ts:186

Returns

number

minute()
Call Signature

minute(minute): this

Defined in: dist/types/index.d.ts:170

Parameters
minute

number

Returns

this

Call Signature

minute(): number

Defined in: dist/types/index.d.ts:171

Returns

number

minutes()
Call Signature

minutes(minutes): this

Defined in: dist/types/index.d.ts:181

Parameters
minutes

number

Returns

this

Call Signature

minutes(): number

Defined in: dist/types/index.d.ts:182

Returns

number

month()
Call Signature

month(month): this

Defined in: dist/types/index.d.ts:162

Parameters
month

number

Returns

this

Call Signature

month(): number

Defined in: dist/types/index.d.ts:163

Returns

number

second()
Call Signature

second(second): this

Defined in: dist/types/index.d.ts:172

Parameters
second

number

Returns

this

Call Signature

second(): number

Defined in: dist/types/index.d.ts:173

Returns

number

seconds()
Call Signature

seconds(seconds): this

Defined in: dist/types/index.d.ts:183

Parameters
seconds

number

Returns

this

Call Signature

seconds(): number

Defined in: dist/types/index.d.ts:184

Returns

number

set()

set(unit, val): this

Defined in: dist/types/index.d.ts:148

Parameters
unit

Unit

val

number

Returns

this

startOf()

startOf(unit): this

Defined in: dist/types/index.d.ts:149

Parameters
unit

Unit

Returns

this

subDays()

subDays(days): this

Defined in: dist/types/index.d.ts:150

Parameters
days

number

Returns

this

subHours()

subHours(hours): this

Defined in: dist/types/index.d.ts:151

Parameters
hours

number

Returns

this

subMilliseconds()

subMilliseconds(time): this

Defined in: dist/types/index.d.ts:152

Parameters
time

number

Returns

this

subMinutes()

subMinutes(minutes): this

Defined in: dist/types/index.d.ts:153

Parameters
minutes

number

Returns

this

subMonths()

subMonths(months): this

Defined in: dist/types/index.d.ts:154

Parameters
months

number

Returns

this

subSeconds()

subSeconds(seconds): this

Defined in: dist/types/index.d.ts:155

Parameters
seconds

number

Returns

this

subtract()
Call Signature

subtract(input): this

Defined in: dist/types/index.d.ts:156

Parameters
input

number | DateAddingObject

Returns

this

Call Signature

subtract(num, unit): this

Defined in: dist/types/index.d.ts:157

Parameters
num

number

unit

Unit

Returns

this

subYears()

subYears(years): this

Defined in: dist/types/index.d.ts:158

Parameters
years

number

Returns

this

time()
Call Signature

time(time): this

Defined in: dist/types/index.d.ts:176

Parameters
time

number

Returns

this

Call Signature

time(): number

Defined in: dist/types/index.d.ts:177

Returns

number

toArray()

toArray(): number[]

Defined in: dist/types/index.d.ts:189

Returns

number[]

toDate()

toDate(): Date

Defined in: dist/types/index.d.ts:190

Returns

Date

toISOString()

toISOString(): string

Defined in: dist/types/index.d.ts:191

Returns

string

toJSON()

toJSON(): string

Defined in: dist/types/index.d.ts:192

Returns

string

toString()

toString(): string

Defined in: dist/types/index.d.ts:193

Returns

string

valueOf()

valueOf(): number

Defined in: dist/types/index.d.ts:194

Returns

number

year()
Call Signature

year(year): this

Defined in: dist/types/index.d.ts:160

Parameters
year

number

Returns

this

Call Signature

year(): number

Defined in: dist/types/index.d.ts:161

Returns

number


InnerDateParsingObject

Defined in: dist/types/index.d.ts:28

Properties

date?

optional date: number

Defined in: dist/types/index.d.ts:31

hour?

optional hour: number

Defined in: dist/types/index.d.ts:32

millisecond?

optional millisecond: number

Defined in: dist/types/index.d.ts:35

minute?

optional minute: number

Defined in: dist/types/index.d.ts:33

month?

optional month: number

Defined in: dist/types/index.d.ts:30

second?

optional second: number

Defined in: dist/types/index.d.ts:34

utcOffset?

optional utcOffset: number

Defined in: dist/types/index.d.ts:36

year?

optional year: number

Defined in: dist/types/index.d.ts:29


InnerUnits

Defined in: dist/types/index.d.ts:55

Properties

DATE

DATE: "date"

Defined in: dist/types/index.d.ts:74

Date unit (日单位)

DAY

DAY: "day"

Defined in: dist/types/index.d.ts:79

Day unit (日单位)

HOUR

HOUR: "hour"

Defined in: dist/types/index.d.ts:84

Hour unit (时单位)

MILLISECOND

MILLISECOND: "millisecond"

Defined in: dist/types/index.d.ts:99

Millisecond unit (毫秒单位)

MINUTE

MINUTE: "minute"

Defined in: dist/types/index.d.ts:89

Minute unit (分单位)

MONTH

MONTH: "month"

Defined in: dist/types/index.d.ts:69

Month unit (月单位)

SECOND

SECOND: "second"

Defined in: dist/types/index.d.ts:94

Second unit (秒单位)

TIME

TIME: "time"

Defined in: dist/types/index.d.ts:59

Time unit (时间单位)

UTC_OFFSET

UTC_OFFSET: "utcOffset"

Defined in: dist/types/index.d.ts:104

UTC offset unit (时区单位)

YEAR

YEAR: "year"

Defined in: dist/types/index.d.ts:64

Year unit (年单位)

Type Aliases

ChainInput

ChainInput = DateInput | IDateChain

Defined in: dist/types/index.d.ts:115


DateInput

DateInput = string | number | Date | number[] | DateParsingObject

Defined in: dist/types/index.d.ts:47

Date input type 日期输入类型


InnerUnit

InnerUnit = "year" | "month" | "date" | "day" | "hour" | "minute" | "second" | "millisecond"

Defined in: dist/types/index.d.ts:53

Internal date unit 内部日期单位


Unit

Unit = "Y" | "y" | "M" | "D" | "d" | "h" | "m" | "s" | "ms" | InnerUnit | "years" | "months" | "dates" | "days" | "hours" | "minutes" | "seconds" | "milliseconds"

Defined in: dist/types/index.d.ts:111

Date unit 日期单位

Variables

units

const units: InnerUnits

Defined in: dist/units.d.ts:2

Functions

add()

Call Signature

add(date, input): Date

Defined in: dist/add.d.ts:2

Parameters
date

Date

input

number | DateAddingObject

Returns

Date

Call Signature

add(date, num, unit): Date

Defined in: dist/add.d.ts:3

Parameters
date

Date

num

number

unit

Unit

Returns

Date


addDays()

addDays(date, days): Date

Defined in: dist/addDays.d.ts:14

Adds a specified number of days to a date. 向日期添加指定数量的天数。

Parameters

date

Date

The date to add days to. (要添加天数的日期。)

days

number

The number of days to add. (要添加的天数。)

Returns

Date

A new date with the added days. (添加天数后的新日期。)

Example

ts
const newDate = addDays(new Date(), 5);
console.log(newDate); // Outputs the date 5 days from now (输出5天后的日期)

addHours()

addHours(date, hours): Date

Defined in: dist/addHours.d.ts:16

Adds a specified number of hours to a date. 向日期添加指定数量的小时。

Parameters

date

Date

The date to add hours to. (要添加小时的日期。)

hours

number

The number of hours to add. (要添加的小时数。)

Returns

Date

A new date with the added hours. (添加小时后的新日期。)

Example

ts
// Adding 3 hours to a date (向日期添加3小时)
const originalDate = new Date('2023-10-01T12:00:00');
addHours(originalDate, 3);
console.log(originalDate.toISOString()); // Outputs: '2023-10-01T15:00:00.000Z' (输出: '2023-10-01T15:00:00.000Z')

addMilliseconds()

addMilliseconds(date, ms): Date

Defined in: dist/addMilliseconds.d.ts:16

Adds a specified number of milliseconds to a date. 向日期添加指定数量的毫秒。

Parameters

date

Date

The date to add milliseconds to. (要添加毫秒的日期。)

ms

number

The number of milliseconds to add. (要添加的毫秒数。)

Returns

Date

A new date with the added milliseconds. (添加毫秒后的新日期。)

Example

ts
// Adding 5000 milliseconds to a date (向日期添加5000毫秒)
const originalDate = new Date('2023-10-01T12:00:00');
addMilliseconds(originalDate, 5000);
console.log(originalDate.toISOString()); // Outputs: '2023-10-01T12:00:05.000Z' (输出: '2023-10-01T12:00:05.000Z')

addMinutes()

addMinutes(date, minutes): Date

Defined in: dist/addMinutes.d.ts:16

Adds a specified number of minutes to a date. 向日期添加指定数量的分钟。

Parameters

date

Date

The date to add minutes to. (要添加分钟的日期。)

minutes

number

The number of minutes to add. (要添加的分钟数。)

Returns

Date

A new date with the added minutes. (添加分钟后的新日期。)

Example

ts
// Adding 30 minutes to a date (向日期添加30分钟)
const originalDate = new Date('2023-10-01T12:00:00');
addMinutes(originalDate, 30);
console.log(originalDate.toISOString()); // Outputs: '2023-10-01T12:30:00.000Z' (输出: '2023-10-01T12:30:00.000Z')

addMonths()

addMonths(date, months): Date

Defined in: dist/addMonths.d.ts:16

Adds a specified number of months to a date. 向日期添加指定数量的月份。

Parameters

date

Date

The date to add months to. (要添加月份的日期。)

months

number

The number of months to add. (要添加的月份数。)

Returns

Date

A new date with the added months. (添加月份后的新日期。)

Example

ts
// Adding 2 months to a date (向日期添加2个月)
const originalDate = new Date('2023-10-31T12:00:00');
addMonths(originalDate, 2);
console.log(originalDate.toISOString()); // Outputs: '2023-12-31T12:00:00.000Z' (输出: '2023-12-31T12:00:00.000Z')

addSeconds()

addSeconds(date, seconds): Date

Defined in: dist/addSeconds.d.ts:16

Adds a specified number of seconds to a date. 向日期添加指定数量的秒。

Parameters

date

Date

The date to add seconds to. (要添加秒的日期。)

seconds

number

The number of seconds to add. (要添加的秒数。)

Returns

Date

A new date with the added seconds. (添加秒后的新日期。)

Example

ts
// Adding 30 seconds to a date (向日期添加30秒)
const originalDate = new Date('2023-10-01T12:00:00');
addSeconds(originalDate, 30);
console.log(originalDate.toISOString()); // Outputs: '2023-10-01T12:00:30.000Z' (输出: '2023-10-01T12:00:30.000Z')

addYears()

addYears(date, years): Date

Defined in: dist/addYears.d.ts:16

Adds a specified number of years to a date. 向日期添加指定数量的年份。

Parameters

date

Date

The date to add years to. (要添加年份的日期。)

years

number

The number of years to add. (要添加的年份数。)

Returns

Date

A new date with the added years. (添加年份后的新日期。)

Example

ts
// Adding 2 years to a date (向日期添加2年)
const originalDate = new Date('2023-10-01T12:00:00');
addYears(originalDate, 2);
console.log(originalDate.toISOString()); // Outputs: '2025-10-01T12:00:00.000Z' (输出: '2025-10-01T12:00:00.000Z')

chain()

chain(input, format?): IDateChain

Defined in: src/chain.ts:144

Parameters

input

ChainInput

format?

string

Returns

IDateChain


compile()

compile(formatString): CompileResult

Defined in: dist/compile.d.ts:21

Compile a format string into a regular expression and extract date parts. 编译格式字符串,生成正则表达式和匹配的日期部分

Parameters

formatString

string

The format string to compile. (要编译的格式字符串。)

Returns

CompileResult

A compiled result object containing the regular expression pattern and extracted date parts. (包含正则表达式模式的编译结果对象,以及提取的日期部分。)

Example

ts
compile('YYYY-MM-DD HH:mm:ss.SSS');
// {
//   pattern: '(\\d{1,4})-(\\d{1,2})-(\\d{1,2}) (\\d{1,2}):(\\d{1,2}):(\\d{1,2})\\.(\\d{1,3})',
//   tokens: ['YYYY', 'MM', 'DD','HH', 'mm', 'ss', 'SSS']
// }

dayOfYear()

Call Signature

dayOfYear(date): number

Defined in: dist/dayOfYear.d.ts:1

Parameters
date

Date

Returns

number

Call Signature

dayOfYear(date, val): Date

Defined in: dist/dayOfYear.d.ts:2

Parameters
date

Date

val

number

Returns

Date


daysInMonth()

daysInMonth(date): number

Defined in: dist/daysInMonth.d.ts:20

Gets the number of days in the month for a given date. 获取给定日期所在月份的天数。

Parameters

date

Date

The date to get the number of days in the month for. (要获取月份天数的日期。)

Returns

number

The number of days in the month. (月份的天数。)

Example

ts
// Getting the number of days in October 2023 (获取2023年10月的天数)
const date = new Date('2023-10-01');
const days = daysInMonth(date);
console.log(days); // Outputs: 31 (输出: 31)

// Getting the number of days in February 2024 (获取2024年2月的天数)
const date2 = new Date('2024-02-01');
const days2 = daysInMonth(date2);
console.log(days2); // Outputs: 29 (输出: 29)

diff()

diff(date, input, unit, asFloat?): number

Defined in: dist/diff.d.ts:46

Calculates the difference between two dates in specified time units. 计算两个日期之间的指定时间单位差异。

Parameters

date

Date

The first date. (第一个日期。)

input

DateInput

The second date. (第二个日期。)

unit

Unit

The unit of time to calculate the difference in (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要计算差异的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

asFloat?

boolean

Whether to return the difference as a floating-point number. (是否以浮点数形式返回差异。)

Returns

number

The difference between the two dates in the specified time units. (两个日期之间的指定时间单位差异。)

Example

ts
// Calculating the difference in years (计算年份差异)
const date1 = new Date('2023-01-01');
const date2 = new Date('2024-01-01');
const yearsDiff = diff(date1, date2, 'year');
console.log(yearsDiff); // Outputs: 1 (输出: 1)

// Calculating the difference in months (计算月份差异)
const monthsDiff = diff(date1, date2, 'month');
console.log(monthsDiff); // Outputs: 12 (输出: 12)

// Calculating the difference in days (计算天数差异)
const daysDiff = diff(date1, date2, 'day');
console.log(daysDiff); // Outputs: 365 (输出: 365)

// Calculating the difference in hours (计算小时差异)
const hoursDiff = diff(date1, date2, 'hour');
console.log(hoursDiff); // Outputs: 8760 (输出: 8760)

// Calculating the difference in minutes (计算分钟差异)
const minutesDiff = diff(date1, date2, 'minute');
console.log(minutesDiff); // Outputs: 525600 (输出: 525600)

// Calculating the difference in seconds (计算秒数差异)
const secondsDiff = diff(date1, date2, 'second');
console.log(secondsDiff); // Outputs: 31536000 (输出: 31536000)

// Calculating the difference in milliseconds (计算毫秒差异)
const msDiff = diff(date1, date2, 'millisecond');
console.log(msDiff); // Outputs: 31536000000 (输出: 31536000000)

diffInDays()

diffInDays(date, input, asFloat?): number

Defined in: dist/diffInDays.d.ts:2

Parameters

date

Date

input

DateInput

asFloat?

boolean

Returns

number


diffInHours()

diffInHours(date, input, asFloat?): number

Defined in: dist/diffInHours.d.ts:2

Parameters

date

Date

input

DateInput

asFloat?

boolean

Returns

number


diffInMilliseconds()

diffInMilliseconds(date, input, asFloat?): number

Defined in: dist/diffInMilliseconds.d.ts:2

Parameters

date

Date

input

DateInput

asFloat?

boolean

Returns

number


diffInMinutes()

diffInMinutes(date, input, asFloat?): number

Defined in: dist/diffInMinutes.d.ts:2

Parameters

date

Date

input

DateInput

asFloat?

boolean

Returns

number


diffInMonths()

diffInMonths(date, input, asFloat?): number

Defined in: dist/diffInMonths.d.ts:2

Parameters

date

Date

input

DateInput

asFloat?

boolean

Returns

number


diffInSeconds()

diffInSeconds(date, input, asFloat?): number

Defined in: dist/diffInSeconds.d.ts:2

Parameters

date

Date

input

DateInput

asFloat?

boolean

Returns

number


diffInYears()

diffInYears(date, input, asFloat?): number

Defined in: dist/diffInYears.d.ts:2

Parameters

date

Date

input

DateInput

asFloat?

boolean

Returns

number


endOf()

endOf(date, unit): Date

Defined in: dist/endOf.d.ts:43

Sets the date to the end of the specified unit of time. 将日期设置为指定时间单位的结束时间。

Parameters

date

Date

The date to set to the end of the specified unit. (要设置为指定时间单位结束时间的日期。)

unit

Unit

The unit of time to set the end of (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second'). (要设置结束时间的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'。)

Returns

Date

A new date object set to the end of the specified unit. (设置为指定时间单位结束时间的新日期对象。)

Example

ts
// Setting the end of the year (设置年份结束时间)
const date1 = new Date('2023-01-01');
const endOfYear = endOf(date1, 'year');
console.log(endOfYear.toISOString()); // Outputs: '2023-12-31T23:59:59.999Z' (输出: '2023-12-31T23:59:59.999Z')

// Setting the end of the month (设置月份结束时间)
const date2 = new Date('2023-10-01');
const endOfMonth = endOf(date2, 'month');
console.log(endOfMonth.toISOString()); // Outputs: '2023-10-31T23:59:59.999Z' (输出: '2023-10-31T23:59:59.999Z')

// Setting the end of the day (设置天数结束时间)
const date3 = new Date('2023-10-01T12:00:00');
const endOfDay = endOf(date3, 'day');
console.log(endOfDay.toISOString()); // Outputs: '2023-10-01T23:59:59.999Z' (输出: '2023-10-01T23:59:59.999Z')

// Setting the end of the hour (设置小时结束时间)
const date4 = new Date('2023-10-01T12:00:00');
const endOfHour = endOf(date4, 'hour');
console.log(endOfHour.toISOString()); // Outputs: '2023-10-01T12:59:59.999Z' (输出: '2023-10-01T12:59:59.999Z')

// Setting the end of the minute (设置分钟结束时间)
const date5 = new Date('2023-10-01T12:00:00');
const endOfMinute = endOf(date5, 'minute');
console.log(endOfMinute.toISOString()); // Outputs: '2023-10-01T12:00:59.999Z' (输出: '2023-10-01T12:00:59.999Z')

// Setting the end of the second (设置秒数结束时间)
const date6 = new Date('2023-10-01T12:00:00');
const endOfSecond = endOf(date6, 'second');
console.log(endOfSecond.toISOString()); // Outputs: '2023-10-01T12:00:00.999Z' (输出: '2023-10-01T12:00:00.999Z')

format()

format(date, formatString?): string

Defined in: dist/format.d.ts:31

Formats a date according to the specified format string. 根据指定的格式字符串格式化日期。

Parameters

date

Date

The date to format. (要格式化的日期。)

formatString?

string

The format string to use. (要使用的格式字符串。)

Returns

string

The formatted date string. (格式化后的日期字符串。)

Example

ts
// Formatting a date with 'YYYY-MM-DD' format (使用 'YYYY-MM-DD' 格式格式化日期)
const date1 = new Date('2023-10-01T12:00:00');
const formattedDate1 = format(date1, 'YYYY-MM-DD');
console.log(formattedDate1); // Outputs: '2023-10-01' (输出: '2023-10-01')

// Formatting a date with 'YYYY-MM-DD HH:mm:ss' format (使用 'YYYY-MM-DD HH:mm:ss' 格式格式化日期)
const date2 = new Date('2023-10-01T12:30:45');
const formattedDate2 = format(date2, 'YYYY-MM-DD HH:mm:ss');
console.log(formattedDate2); // Outputs: '2023-10-01 12:30:45' (输出: '2023-10-01 12:30:45')

// Formatting a date with 'YYYY-MM-DDTHH:mm:ssZ' format (使用 'YYYY-MM-DDTHH:mm:ssZ' 格式格式化日期)
const date3 = new Date('2023-10-01T12:30:45');
const formattedDate3 = format(date3, 'YYYY-MM-DDTHH:mm:ssZ');
console.log(formattedDate3); // Outputs: '2023-10-01T12:30:45-04:00' (输出: '2023-10-01T12:30:45-04:00')

// Using 'ISO' format (使用 'ISO' 格式)
const date4 = new Date('2023-10-01T12:30:45');
const formattedDate4 = format(date4, 'ISO');
console.log(formattedDate4); // Outputs: '2023-10-01T16:30:45.000Z' (输出: '2023-10-01T16:30:45.000Z')

get()

get(date, unit): number

Defined in: dist/_internal/getOrSet.d.ts:42

Retrieves the value of a specified time unit for a given date. 获取给定日期的指定时间单位的值。

Parameters

date

Date

The date from which to retrieve the time unit value. (要从中获取时间单位值的日期。)

unit

Unit

The unit of time to retrieve (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要获取的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

Returns

number

The value of the specified time unit. (指定时间单位的值。)

Example

ts
// Getting the year of a date (获取日期的年份)
const date = new Date('2023-10-01');
const year = get(date, 'year');
console.log(year); // Outputs: 2023 (输出: 2023)

// Getting the month of a date (获取日期的月份)
const month = get(date, 'month');
console.log(month); // Outputs: 9 (输出: 9,注意月份是从0开始的)

// Getting the day of a date (获取日期的天数)
const day = get(date, 'day');
console.log(day); // Outputs: 1 (输出: 1)

// Getting the hour of a date (获取日期的小时)
const hour = get(date, 'hour');
console.log(hour); // Outputs: 0 (输出: 0)

// Getting the minute of a date (获取日期的分钟)
const minute = get(date, 'minute');
console.log(minute); // Outputs: 0 (输出: 0)

// Getting the second of a date (获取日期的秒数)
const second = get(date, 'second');
console.log(second); // Outputs: 0 (输出: 0)

// Getting the millisecond of a date (获取日期的毫秒数)
const millisecond = get(date, 'millisecond');
console.log(millisecond); // Outputs: 0 (输出: 0)

isAfter()

isAfter(date, input, unit?): boolean

Defined in: dist/isAfter.d.ts:56

Checks if a date is after another date or a specified time unit. 检查一个日期是否在另一个日期或指定的时间单位之后。

Parameters

date

Date

The date to compare. (要比较的日期。)

input

DateInput

The date or time unit to compare against. (要比较的日期或时间单位。)

unit?

Unit

The unit of time to compare (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要比较的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

Returns

boolean

A boolean indicating whether the first date is after the second date or time unit. (布尔值,表示第一个日期是否在第二个日期或时间单位之后。)

Example

ts
// Checking if a date is after another date (检查一个日期是否在另一个日期之后)
const date1 = new Date('2023-10-01');
const date2 = new Date('2023-09-01');
const isAfterDate = isAfter(date1, date2, 'day');
console.log(isAfterDate); // Outputs: true (输出: true)

// Checking if a date is after a specific year (检查一个日期是否在特定年份之后)
const date3 = new Date('2024-01-01');
const isAfterYear = isAfter(date3, 2023, 'year');
console.log(isAfterYear); // Outputs: true (输出: true)

// Checking if a date is after a specific month (检查一个日期是否在特定月份之后)
const date4 = new Date('2023-11-01');
const isAfterMonth = isAfter(date4, '2023-10', 'month');
console.log(isAfterMonth); // Outputs: true (输出: true)

// Checking if a date is after a specific day (检查一个日期是否在特定天数之后)
const date5 = new Date('2023-10-02');
const isAfterDay = isAfter(date5, '2023-10-01', 'day');
console.log(isAfterDay); // Outputs: true (输出: true)

// Checking if a date is after a specific hour (检查一个日期是否在特定小时之后)
const date6 = new Date('2023-10-01T13:00:00');
const isAfterHour = isAfter(date6, '2023-10-01T12:00:00', 'hour');
console.log(isAfterHour); // Outputs: true (输出: true)

// Checking if a date is after a specific minute (检查一个日期是否在特定分钟之后)
const date7 = new Date('2023-10-01T12:01:00');
const isAfterMinute = isAfter(date7, '2023-10-01T12:00:00', 'minute');
console.log(isAfterMinute); // Outputs: true (输出: true)

// Checking if a date is after a specific second (检查一个日期是否在特定秒数之后)
const date8 = new Date('2023-10-01T12:00:01');
const isAfterSecond = isAfter(date8, '2023-10-01T12:00:00', 'second');
console.log(isAfterSecond); // Outputs: true (输出: true)

// Checking if a date is after a specific millisecond (检查一个日期是否在特定毫秒数之后)
const date9 = new Date('2023-10-01T12:00:00.500');
const isAfterMillisecond = isAfter(date9, '2023-10-01T12:00:00.000', 'millisecond');
console.log(isAfterMillisecond); // Outputs: true (输出: true)

isBefore()

isBefore(date, input, unit?): boolean

Defined in: dist/isBefore.d.ts:56

Checks if a date is before another date or a specified time unit. 检查一个日期是否在另一个日期或指定的时间单位之前。

Parameters

date

Date

The date to compare. (要比较的日期。)

input

DateInput

The date or time unit to compare against. (要比较的日期或时间单位。)

unit?

Unit

The unit of time to compare (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要比较的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

Returns

boolean

A boolean indicating whether the first date is before the second date or time unit. (布尔值,表示第一个日期是否在第二个日期或时间单位之前。)

Example

ts
// Checking if a date is before another date (检查一个日期是否在另一个日期之前)
const date1 = new Date('2023-09-01');
const date2 = new Date('2023-10-01');
const isBeforeDate = isBefore(date1, date2, 'day');
console.log(isBeforeDate); // Outputs: true (输出: true)

// Checking if a date is before a specific year (检查一个日期是否在特定年份之前)
const date3 = new Date('2022-12-31');
const isBeforeYear = isBefore(date3, 2023, 'year');
console.log(isBeforeYear); // Outputs: true (输出: true)

// Checking if a date is before a specific month (检查一个日期是否在特定月份之前)
const date4 = new Date('2023-09-01');
const isBeforeMonth = isBefore(date4, '2023-10', 'month');
console.log(isBeforeMonth); // Outputs: true (输出: true)

// Checking if a date is before a specific day (检查一个日期是否在特定天数之前)
const date5 = new Date('2023-10-01');
const isBeforeDay = isBefore(date5, '2023-10-02', 'day');
console.log(isBeforeDay); // Outputs: true (输出: true)

// Checking if a date is before a specific hour (检查一个日期是否在特定小时之前)
const date6 = new Date('2023-10-01T12:00:00');
const isBeforeHour = isBefore(date6, '2023-10-01T13:00:00', 'hour');
console.log(isBeforeHour); // Outputs: true (输出: true)

// Checking if a date is before a specific minute (检查一个日期是否在特定分钟之前)
const date7 = new Date('2023-10-01T12:00:00');
const isBeforeMinute = isBefore(date7, '2023-10-01T12:01:00', 'minute');
console.log(isBeforeMinute); // Outputs: true (输出: true)

// Checking if a date is before a specific second (检查一个日期是否在特定秒数之前)
const date8 = new Date('2023-10-01T12:00:00');
const isBeforeSecond = isBefore(date8, '2023-10-01T12:00:01', 'second');
console.log(isBeforeSecond); // Outputs: true (输出: true)

// Checking if a date is before a specific millisecond (检查一个日期是否在特定毫秒数之前)
const date9 = new Date('2023-10-01T12:00:00.000');
const isBeforeMillisecond = isBefore(date9, '2023-10-01T12:00:00.500', 'millisecond');
console.log(isBeforeMillisecond); // Outputs: true (输出: true)

isBetween()

isBetween(date, from, to, unit?, inclusivity?): boolean

Defined in: dist/isBetween.d.ts:72

Checks if a date is between two other dates or specified time units. 检查一个日期是否在两个其他日期或指定的时间单位之间。

Parameters

date

Date

The date to check. (要检查的日期。)

from

DateInput

The start date or time unit. (起始日期或时间单位。)

to

DateInput

The end date or time unit. (结束日期或时间单位。)

unit?

Unit

The unit of time to compare (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要比较的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

inclusivity?

string

A string indicating whether the comparison is inclusive or exclusive. (表示比较是否包含边界的字符串。) - '()' means exclusive (不包含边界) (默认值) - '[)' means inclusive on the start, exclusive on the end (包含起始边界,不包含结束边界) - '(]' means exclusive on the start, inclusive on the end (不包含起始边界,包含结束边界) - '[]' means inclusive (包含边界)

Returns

boolean

A boolean indicating whether the date is between the two specified dates or time units. (布尔值,表示日期是否在两个指定的日期或时间单位之间。)

Example

ts
// Checking if a date is between two dates (检查一个日期是否在两个日期之间)
const date = new Date('2023-10-01');
const from = new Date('2023-09-01');
const to = new Date('2023-11-01');
const isBetweenDates = isBetween(date, from, to, 'day');
console.log(isBetweenDates); // Outputs: true (输出: true)

// Checking if a date is between two years (检查一个日期是否在两个年份之间)
const date2 = new Date('2023-01-01');
const isBetweenYears = isBetween(date2, 2022, 2024, 'year');
console.log(isBetweenYears); // Outputs: true (输出: true)

// Checking if a date is between two months (检查一个日期是否在两个月份之间)
const date3 = new Date('2023-10-01');
const isBetweenMonths = isBetween(date3, '2023-09', '2023-11', 'month');
console.log(isBetweenMonths); // Outputs: true (输出: true)

// Checking if a date is between two days (检查一个日期是否在两个天数之间)
const date4 = new Date('2023-10-02');
const isBetweenDays = isBetween(date4, '2023-10-01', '2023-10-03', 'day');
console.log(isBetweenDays); // Outputs: true (输出: true)

// Checking if a date is between two hours (检查一个日期是否在两个小时之间)
const date5 = new Date('2023-10-01T12:00:00');
const isBetweenHours = isBetween(date5, '2023-10-01T11:00:00', '2023-10-01T13:00:00', 'hour');
console.log(isBetweenHours); // Outputs: true (输出: true)

// Checking if a date is between two minutes (检查一个日期是否在两个分钟之间)
const date6 = new Date('2023-10-01T12:01:00');
const isBetweenMinutes = isBetween(date6, '2023-10-01T12:00:00', '2023-10-01T12:02:00', 'minute');
console.log(isBetweenMinutes); // Outputs: true (输出: true)

// Checking if a date is between two seconds (检查一个日期是否在两个秒数之间)
const date7 = new Date('2023-10-01T12:00:01');
const isBetweenSeconds = isBetween(date7, '2023-10-01T12:00:00', '2023-10-01T12:00:02', 'second');
console.log(isBetweenSeconds); // Outputs: true (输出: true)

// Checking if a date is between two milliseconds (检查一个日期是否在两个毫秒数之间)
const date8 = new Date('2023-10-01T12:00:00.500');
const isBetweenMilliseconds = isBetween(date8, '2023-10-01T12:00:00.000', '2023-10-01T12:00:00.999', 'millisecond');
console.log(isBetweenMilliseconds); // Outputs: true (输出: true)

// Using different inclusivity options (使用不同的包含选项)
const date9 = new Date('2023-10-01');
const isBetweenInclusive = isBetween(date9, '2023-10-01', '2023-10-01', 'day', '[]');
console.log(isBetweenInclusive); // Outputs: true (输出: true)

const isBetweenExclusive = isBetween(date9, '2023-10-01', '2023-10-01', 'day', '()');
console.log(isBetweenExclusive); // Outputs: false (输出: false)

isLeapYear()

isLeapYear(date): boolean

Defined in: dist/isLeapYear.d.ts:20

Checks if a given date is in a leap year. 检查给定的日期是否在闰年。

Parameters

date

Date

The date to check. (要检查的日期。)

Returns

boolean

A boolean indicating whether the given date is in a leap year. (布尔值,表示给定的日期是否在闰年。)

Example

ts
// Checking if a date is in a leap year (检查一个日期是否在闰年)
const date1 = new Date('2024-01-01');
const isLeap = isLeapYear(date1);
console.log(isLeap); // Outputs: true (输出: true)

// Checking if a date is not in a leap year (检查一个日期是否不在闰年)
const date2 = new Date('2023-01-01');
const isNotLeap = isLeapYear(date2);
console.log(isNotLeap); // Outputs: false (输出: false)

isSame()

isSame(date, input, unit?): boolean

Defined in: dist/isSame.d.ts:56

Checks if a date is the same as another date or a specified time unit. 检查一个日期是否与另一个日期或指定的时间单位相同。

Parameters

date

Date

The date to compare. (要比较的日期。)

input

DateInput

The date or time unit to compare against. (要比较的日期或时间单位。)

unit?

Unit

The unit of time to compare (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要比较的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

Returns

boolean

A boolean indicating whether the first date is the same as the second date or time unit. (布尔值,表示第一个日期是否与第二个日期或时间单位相同。)

Example

ts
// Checking if a date is the same as another date (检查一个日期是否与另一个日期相同)
const date1 = new Date('2023-10-01');
const date2 = new Date('2023-10-01');
const isSameDate = isSame(date1, date2, 'day');
console.log(isSameDate); // Outputs: true (输出: true)

// Checking if a date is the same as a specific year (检查一个日期是否与特定年份相同)
const date3 = new Date('2023-10-01');
const isSameYear = isSame(date3, 2023, 'year');
console.log(isSameYear); // Outputs: true (输出: true)

// Checking if a date is the same as a specific month (检查一个日期是否与特定月份相同)
const date4 = new Date('2023-10-01');
const isSameMonth = isSame(date4, '2023-10', 'month');
console.log(isSameMonth); // Outputs: true (输出: true)

// Checking if a date is the same as a specific day (检查一个日期是否与特定天数相同)
const date5 = new Date('2023-10-01');
const isSameDay = isSame(date5, '2023-10-01', 'day');
console.log(isSameDay); // Outputs: true (输出: true)

// Checking if a date is the same as a specific hour (检查一个日期是否与特定小时相同)
const date6 = new Date('2023-10-01T12:00:00');
const isSameHour = isSame(date6, '2023-10-01T12:00:00', 'hour');
console.log(isSameHour); // Outputs: true (输出: true)

// Checking if a date is the same as a specific minute (检查一个日期是否与特定分钟相同)
const date7 = new Date('2023-10-01T12:00:00');
const isSameMinute = isSame(date7, '2023-10-01T12:00:00', 'minute');
console.log(isSameMinute); // Outputs: true (输出: true)

// Checking if a date is the same as a specific second (检查一个日期是否与特定秒数相同)
const date8 = new Date('2023-10-01T12:00:00');
const isSameSecond = isSame(date8, '2023-10-01T12:00:00', 'second');
console.log(isSameSecond); // Outputs: true (输出: true)

// Checking if a date is the same as a specific millisecond (检查一个日期是否与特定毫秒数相同)
const date9 = new Date('2023-10-01T12:00:00.000');
const isSameMillisecond = isSame(date9, '2023-10-01T12:00:00.000', 'millisecond');
console.log(isSameMillisecond); // Outputs: true (输出: true)

isSameOrAfter()

isSameOrAfter(date, input, unit?): boolean

Defined in: dist/isSameOrAfter.d.ts:61

Checks if a date is the same as or after another date or a specified time unit. 检查一个日期是否与另一个日期或指定的时间单位相同或在其之后。

Parameters

date

Date

The date to compare. (要比较的日期。)

input

DateInput

The date or time unit to compare against. (要比较的日期或时间单位。)

unit?

Unit

The unit of time to compare (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要比较的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

Returns

boolean

A boolean indicating whether the first date is the same as or after the second date or time unit. (布尔值,表示第一个日期是否与第二个日期或时间单位相同或在其之后。)

Example

ts
// Checking if a date is the same as or after another date (检查一个日期是否与另一个日期相同或在其之后)
const date1 = new Date('2023-10-01');
const date2 = new Date('2023-10-01');
const isSameOrAfterDate = isSameOrAfter(date1, date2, 'day');
console.log(isSameOrAfterDate); // Outputs: true (输出: true)

// Checking if a date is after another date (检查一个日期是否在另一个日期之后)
const date3 = new Date('2023-10-02');
const isSameOrAfterDate2 = isSameOrAfter(date3, date2, 'day');
console.log(isSameOrAfterDate2); // Outputs: true (输出: true)

// Checking if a date is the same as or after a specific year (检查一个日期是否与特定年份相同或在其之后)
const date4 = new Date('2023-01-01');
const isSameOrAfterYear = isSameOrAfter(date4, 2023, 'year');
console.log(isSameOrAfterYear); // Outputs: true (输出: true)

// Checking if a date is the same as or after a specific month (检查一个日期是否与特定月份相同或在其之后)
const date5 = new Date('2023-10-01');
const isSameOrAfterMonth = isSameOrAfter(date5, '2023-10', 'month');
console.log(isSameOrAfterMonth); // Outputs: true (输出: true)

// Checking if a date is the same as or after a specific day (检查一个日期是否与特定天数相同或在其之后)
const date6 = new Date('2023-10-01');
const isSameOrAfterDay = isSameOrAfter(date6, '2023-10-01', 'day');
console.log(isSameOrAfterDay); // Outputs: true (输出: true)

// Checking if a date is the same as or after a specific hour (检查一个日期是否与特定小时相同或在其之后)
const date7 = new Date('2023-10-01T12:00:00');
const isSameOrAfterHour = isSameOrAfter(date7, '2023-10-01T12:00:00', 'hour');
console.log(isSameOrAfterHour); // Outputs: true (输出: true)

// Checking if a date is the same as or after a specific minute (检查一个日期是否与特定分钟相同或在其之后)
const date8 = new Date('2023-10-01T12:00:00');
const isSameOrAfterMinute = isSameOrAfter(date8, '2023-10-01T12:00:00', 'minute');
console.log(isSameOrAfterMinute); // Outputs: true (输出: true)

// Checking if a date is the same as or after a specific second (检查一个日期是否与特定秒数相同或在其之后)
const date9 = new Date('2023-10-01T12:00:00');
const isSameOrAfterSecond = isSameOrAfter(date9, '2023-10-01T12:00:00', 'second');
console.log(isSameOrAfterSecond); // Outputs: true (输出: true)

// Checking if a date is the same as or after a specific millisecond (检查一个日期是否与特定毫秒数相同或在其之后)
const date10 = new Date('2023-10-01T12:00:00.000');
const isSameOrAfterMillisecond = isSameOrAfter(date10, '2023-10-01T12:00:00.000', 'millisecond');
console.log(isSameOrAfterMillisecond); // Outputs: true (输出: true)

isSameOrBefore()

isSameOrBefore(date, input, unit?): boolean

Defined in: dist/isSameOrBefore.d.ts:61

Checks if a date is the same as or before another date or a specified time unit. 检查一个日期是否与另一个日期或指定的时间单位相同或在其之前。

Parameters

date

Date

The date to compare. (要比较的日期。)

input

DateInput

The date or time unit to compare against. (要比较的日期或时间单位。)

unit?

Unit

The unit of time to compare (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要比较的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

Returns

boolean

A boolean indicating whether the first date is the same as or before the second date or time unit. (布尔值,表示第一个日期是否与第二个日期或时间单位相同或在其之前。)

Example

ts
// Checking if a date is the same as or before another date (检查一个日期是否与另一个日期相同或在其之前)
const date1 = new Date('2023-10-01');
const date2 = new Date('2023-10-01');
const isSameOrBeforeDate = isSameOrBefore(date1, date2, 'day');
console.log(isSameOrBeforeDate); // Outputs: true (输出: true)

// Checking if a date is before another date (检查一个日期是否在另一个日期之前)
const date3 = new Date('2023-09-30');
const isSameOrBeforeDate2 = isSameOrBefore(date3, date2, 'day');
console.log(isSameOrBeforeDate2); // Outputs: true (输出: true)

// Checking if a date is the same as or before a specific year (检查一个日期是否与特定年份相同或在其之前)
const date4 = new Date('2022-12-31');
const isSameOrBeforeYear = isSameOrBefore(date4, 2023, 'year');
console.log(isSameOrBeforeYear); // Outputs: true (输出: true)

// Checking if a date is the same as or before a specific month (检查一个日期是否与特定月份相同或在其之前)
const date5 = new Date('2023-09-30');
const isSameOrBeforeMonth = isSameOrBefore(date5, '2023-10', 'month');
console.log(isSameOrBeforeMonth); // Outputs: true (输出: true)

// Checking if a date is the same as or before a specific day (检查一个日期是否与特定天数相同或在其之前)
const date6 = new Date('2023-10-01');
const isSameOrBeforeDay = isSameOrBefore(date6, '2023-10-01', 'day');
console.log(isSameOrBeforeDay); // Outputs: true (输出: true)

// Checking if a date is the same as or before a specific hour (检查一个日期是否与特定小时相同或在其之前)
const date7 = new Date('2023-10-01T12:00:00');
const isSameOrBeforeHour = isSameOrBefore(date7, '2023-10-01T12:00:00', 'hour');
console.log(isSameOrBeforeHour); // Outputs: true (输出: true)

// Checking if a date is the same as or before a specific minute (检查一个日期是否与特定分钟相同或在其之前)
const date8 = new Date('2023-10-01T12:00:00');
const isSameOrBeforeMinute = isSameOrBefore(date8, '2023-10-01T12:00:00', 'minute');
console.log(isSameOrBeforeMinute); // Outputs: true (输出: true)

// Checking if a date is the same as or before a specific second (检查一个日期是否与特定秒数相同或在其之前)
const date9 = new Date('2023-10-01T12:00:00');
const isSameOrBeforeSecond = isSameOrBefore(date9, '2023-10-01T12:00:00', 'second');
console.log(isSameOrBeforeSecond); // Outputs: true (输出: true)

// Checking if a date is the same as or before a specific millisecond (检查一个日期是否与特定毫秒数相同或在其之前)
const date10 = new Date('2023-10-01T12:00:00.000');
const isSameOrBeforeMillisecond = isSameOrBefore(date10, '2023-10-01T12:00:00.000', 'millisecond');
console.log(isSameOrBeforeMillisecond); // Outputs: true (输出: true)

isValid()

isValid(date): boolean

Defined in: dist/isValid.d.ts:20

Checks if a given date is valid. 检查给定的日期是否有效。

Parameters

date

Date

The date to check. (要检查的日期。)

Returns

boolean

A boolean indicating whether the given date is valid. (布尔值,表示给定的日期是否有效。)

Example

ts
// Checking if a date is valid (检查一个日期是否有效)
const date1 = new Date('2023-10-01');
const isValidDate1 = isValid(date1);
console.log(isValidDate1); // Outputs: true (输出: true)

// Checking if an invalid date is valid (检查一个无效的日期是否有效)
const date2 = new Date('invalid-date');
const isValidDate2 = isValid(date2);
console.log(isValidDate2); // Outputs: false (输出: false)

parse()

parse(input, format?): Date

Defined in: dist/parse.d.ts:35

Parses a date from various input types. 从各种输入类型中解析日期。

Parameters

input

The input to parse, which can be a string, number, Date, or array of numbers. (要解析的输入,可以是字符串、数字、Date 对象或数字数组。)

DateInput | { isValid: () => any; }

format?

string

An optional format string that specifies the format of the input string if the input is a string. Or A boolean indicating whether the date should be in UTC. (可选的格式字符串,指定输入字符串的格式,如果输入是字符串。 或者是布尔值,表示日期是否应为 UTC。)

Returns

Date

A Date object representing the parsed date. (表示解析后日期的 Date 对象。)

Example

ts
// 从字符串中解析日期
const result = parse('20231001123456', 'YYYYMMDDHHmmss');
console.log(result); // 输出: 2023-10-01T12:34:56.000Z

// 从 ISO 8601 字符串中解析日期
const isoResult = parse('2023-10-01T12:34:56Z');
console.log(isoResult); // 输出: 2023-10-01T12:34:56.000Z

// 从数字数组中解析日期
const arrayResult = parse([2023, 9, 1, 12, 34, 56]);
console.log(arrayResult); // 输出: 2023-10-01T12:34:56.000Z

// 从数字中解析日期
const numberResult = parse(1696119296000);
console.log(numberResult); // 输出: 2023-10-01T12:34:56.000Z

// 从 Date 对象中解析日期
const dateResult = parse(new Date('2023-10-01T12:34:56Z'));
console.log(dateResult); // 输出: 2023-10-01T12:34:56.000Z

set()

set(date, unit, val): Date

Defined in: dist/_internal/getOrSet.d.ts:85

Sets the value of a specified time unit for a given date. 设置给定日期的指定时间单位的值。

Parameters

date

Date

The date for which to set the time unit value. (要设置时间单位值的日期。)

unit

Unit

The unit of time to set (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second', 'millisecond'). (要设置的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'、'millisecond'。)

val

number

The value to set for the specified time unit. (要设置的时间单位的值。)

Returns

Date

The modified date with the specified time unit set. (设置指定时间单位后修改的日期。)

Example

ts
// Setting the year of a date (设置日期的年份)
const date = new Date('2023-10-01');
const newDate = set(date, 'year', 2024);
console.log(newDate.toISOString()); // Outputs: '2024-10-01T00:00:00.000Z' (输出: '2024-10-01T00:00:00.000Z')

// Setting the month of a date (设置日期的月份)
const newDateWithMonth = set(date, 'month', 11);
console.log(newDateWithMonth.toISOString()); // Outputs: '2024-12-01T00:00:00.000Z' (输出: '2024-12-01T00:00:00.000Z')

// Setting the day of a date (设置日期的天数)
const newDateWithDay = set(date, 'day', 15);
console.log(newDateWithDay.toISOString()); // Outputs: '2024-12-15T00:00:00.000Z' (输出: '2024-12-15T00:00:00.000Z')

// Setting the hour of a date (设置日期的小时)
const newDateWithHour = set(date, 'hour', 12);
console.log(newDateWithHour.toISOString()); // Outputs: '2024-12-15T12:00:00.000Z' (输出: '2024-12-15T12:00:00.000Z')

// Setting the minute of a date (设置日期的分钟)
const newDateWithMinute = set(date, 'minute', 30);
console.log(newDateWithMinute.toISOString()); // Outputs: '2024-12-15T12:30:00.000Z' (输出: '2024-12-15T12:30:00.000Z')

// Setting the second of a date (设置日期的秒数)
const newDateWithSecond = set(date, 'second', 45);
console.log(newDateWithSecond.toISOString()); // Outputs: '2024-12-15T12:30:45.000Z' (输出: '2024-12-15T12:30:45.000Z')

// Setting the millisecond of a date (设置日期的毫秒数)
const newDateWithMillisecond = set(date, 'millisecond', 500);
console.log(newDateWithMillisecond.toISOString()); // Outputs: '2024-12-15T12:30:45.500Z'
(输出: '2024-12-15T12:30:45.500Z')

startOf()

startOf(date, unit): Date

Defined in: dist/startOf.d.ts:43

Sets the date to the start of the specified unit of time. 将日期设置为指定时间单位的开始时间。

Parameters

date

Date

The date to set to the start of the specified unit. (要设置为指定时间单位开始时间的日期。)

unit

Unit

The unit of time to set the start of (e.g., 'year', 'month', 'day', 'hour', 'minute', 'second'). (要设置开始时间的时间单位,例如 'year'、'month'、'day'、'hour'、'minute'、'second'。)

Returns

Date

A new date object set to the start of the specified unit. (设置为指定时间单位开始时间的新日期对象。)

Example

ts
// Setting the start of the year (设置年份开始时间)
const date1 = new Date('2023-10-01');
const startOfYear = startOf(date1, 'year');
console.log(startOfYear.toISOString()); // Outputs: '2023-01-01T00:00:00.000Z' (输出: '2023-01-01T00:00:00.000Z')

// Setting the start of the month (设置月份开始时间)
const date2 = new Date('2023-10-01');
const startOfMonth = startOf(date2, 'month');
console.log(startOfMonth.toISOString()); // Outputs: '2023-10-01T00:00:00.000Z' (输出: '2023-10-01T00:00:00.000Z')

// Setting the start of the day (设置天数开始时间)
const date3 = new Date('2023-10-01T12:30:45');
const startOfDay = startOf(date3, 'day');
console.log(startOfDay.toISOString()); // Outputs: '2023-10-01T00:00:00.000Z' (输出: '2023-10-01T00:00:00.000Z')

// Setting the start of the hour (设置小时开始时间)
const date4 = new Date('2023-10-01T12:30:45');
const startOfHour = startOf(date4, 'hour');
console.log(startOfHour.toISOString()); // Outputs: '2023-10-01T12:00:00.000Z' (输出: '2023-10-01T12:00:00.000Z')

// Setting the start of the minute (设置分钟开始时间)
const date5 = new Date('2023-10-01T12:30:45');
const startOfMinute = startOf(date5, 'minute');
console.log(startOfMinute.toISOString()); // Outputs: '2023-10-01T12:30:00.000Z' (输出: '2023-10-01T12:30:00.000Z')

// Setting the start of the second (设置秒数开始时间)
const date6 = new Date('2023-10-01T12:30:45.678');
const startOfSecond = startOf(date6, 'second');
console.log(startOfSecond.toISOString()); // Outputs: '2023-10-01T12:30:45.000Z' (输出: '2023-10-01T12:30:45.000Z')

subDays()

subDays(date, days): Date

Defined in: dist/subDays.d.ts:14

Subtracts a specified number of days from a date. 从日期中减去指定数量的天数。

Parameters

date

Date

The date to subtract days from. (要减去天数的日期。)

days

number

The number of days to subtract. (要减去的天数。)

Returns

Date

A new date with the subtracted days. (减去天数后的新日期。)

Example

ts
const newDate = subDays(new Date(), 5);
console.log(newDate); // Outputs the date 5 days ago (输出5天前的日期)

subHours()

subHours(date, hours): Date

Defined in: dist/subHours.d.ts:15

Subtracts a specified number of hours from a date. 从日期中减去指定数量的小时。

Parameters

date

Date

The date to subtract hours from. (要从日期中减去的小时数。)

hours

number

The number of hours to subtract. (要减去的小时数。)

Returns

Date

A new date with the subtracted hours. (减去小时后的新日期。)

Example

ts
//Subtracting 3 hours from a date (从日期中减去3)
subHours(new Date(2014, 6, 2, 11, 55), 3);
//=> Thu Jul 02 2015 08:55:00

subMilliseconds()

subMilliseconds(date, ms): Date

Defined in: dist/subMilliseconds.d.ts:15

Subtracts a specified number of milliseconds from a date. 从日期中减去指定的毫秒数。

Parameters

date

Date

The date to subtract milliseconds from. (要从中减去毫秒的日期。)

ms

number

The number of milliseconds to subtract. (要减去的毫秒数。)

Returns

Date

A new date with the subtracted milliseconds. (减去毫秒后的新日期。)

Example

typescript
// Subtract 500 milliseconds from 10/31/2021 5:45:50 PM
const result = subMilliseconds(new Date(2021, 9, 31, 17, 45, 50, 500), 500);
//=> Thu Oct 31 2021 17:45:49.000

subMinutes()

subMinutes(date, minutes): Date

Defined in: dist/subMinutes.d.ts:16

Subtracts a specified number of minutes from a date. 从日期中减去指定数量的分钟。

Parameters

date

Date

The date to subtract minutes from. (要从日期中减去的日期。)

minutes

number

The number of minutes to subtract. (要减去的分钟数。)

Returns

Date

A new date with the subtracted minutes. (减去分钟后的新日期。)

Example

ts
// Subtracting 30 minutes from a date (从日期中减去30分钟)
const date = new Date('2023-10-01T12:00:00Z');
subMinutes(date, 30);
// Returns: 2023-10-01T11:30:00.000Z (返回: 2023-10-01T11:30:00.000Z)

subMonths()

subMonths(date, months): Date

Defined in: dist/subMonths.d.ts:16

Subtracts a specified number of months from a date. 从日期中减去指定数量的月份。

Parameters

date

Date

The date to subtract months from. (要减去月份的日期。)

months

number

The number of months to subtract. (要减去的月份数。)

Returns

Date

A new date with the subtracted months. (减去月份后的新日期。)

Example

ts
//Subtracting 2 months from a date (从日期中减去2)
const date = new Date('2023-10-31T12:00:00Z');
subMonths(date, 2);
// Returns: 2023-08-31T12:00:00Z (返回: 2023-08-31T12:00:00Z)

subSeconds()

subSeconds(date, seconds): Date

Defined in: dist/subSeconds.d.ts:15

Subtracts a specified number of seconds from a date. 从日期中减去指定数量的秒。

Parameters

date

Date

The date to subtract seconds from. (要从日期中减去秒的日期。)

seconds

number

The number of seconds to subtract. (要减去的秒数。)

Returns

Date

A new date with the subtracted seconds. (减去秒后的新日期。)

Example

ts
// Subtracting 30 seconds from a date (从日期中减)
subSeconds(new Date(2014, 1, 28, 0, 30, 40), 30);
//=> Thu Feb 27 2014 23:59:10

subtract()

Call Signature

subtract(date, input): Date

Defined in: dist/subtract.d.ts:2

Parameters
date

Date

input

number | DateAddingObject

Returns

Date

Call Signature

subtract(date, num, unit): Date

Defined in: dist/subtract.d.ts:3

Parameters
date

Date

num

number

unit

Unit

Returns

Date


subYears()

subYears(date, years): Date

Defined in: dist/subYears.d.ts:16

Subtracts a specified number of years from a date. 从日期中减去指定数量的年份。

Parameters

date

Date

The date to subtract years from. (要减去年份的日期。)

years

number

The number of years to subtract. (要减去的年份数。)

Returns

Date

A new date with the subtracted years. (减去年份后的新日期。)

Example

ts
//Subtracting 2 years from a date (从日期中减去2)
const date = new Date('2023-10-01T12:00:00Z');
subYears(date, 2);
// Returns: 2021-10-01T12:00:00.000Z (返回: 2021-10-01T12:00:00.000Z)