2017-08-03 201 views
30

如何在TypeScript中表示日期?日期不是TypeScript type,所以我使用anyobject?好像有將是一個「正確」的方式來做到:Typescript日期類型?

let myDate: any = new Date(); 

我找不到太多的谷歌,儘管它是這樣一個簡單的問題。

+2

JS類型TS工作。 – Amy

+1

您可以使用接口和類作爲類型。 –

回答

41

答案是超級簡單,類型爲Date

const d: Date = new Date(); // but the type can also be inferred from "new Date()" already 

這是相同的,與

17

任何類或接口可以被用作在一打字原稿類型的每個其它對象實例:) 。

const date = new Date(); 

將已經知道date類型定義爲Date是由DateConstructor接口引用的內部打字稿對象。

而對於你所使用的構造函數,它被定義爲:

interface DateConstructor { 
    new(): Date; 
    ... 
} 

爲了使它更加明確,你可以使用:

const date: Date = new Date(); 

你可能會雖然,缺少類型定義Date來自我的例子從ES6庫,並在我的tsconfig.json我已經定義:

"compilerOptions": { 
    "target": "ES6", 
    "lib": [ 
     "es6", 
     "dom" 
    ], 

您可能會修改這些設置以定位您想要的JavaScript版本。


的日期是由從方式的lib.es6.d.ts接口:

/** Enables basic storage and retrieval of dates and times. */ 
interface Date { 
    /** Returns a string representation of a date. The format of the string depends on the locale. */ 
    toString(): string; 
    /** Returns a date as a string value. */ 
    toDateString(): string; 
    /** Returns a time as a string value. */ 
    toTimeString(): string; 
    /** Returns a value as a string value appropriate to the host environment's current locale. */ 
    toLocaleString(): string; 
    /** Returns a date as a string value appropriate to the host environment's current locale. */ 
    toLocaleDateString(): string; 
    /** Returns a time as a string value appropriate to the host environment's current locale. */ 
    toLocaleTimeString(): string; 
    /** Returns the stored time value in milliseconds since midnight, January 1, 1970 UTC. */ 
    valueOf(): number; 
    /** Gets the time value in milliseconds. */ 
    getTime(): number; 
    /** Gets the year, using local time. */ 
    getFullYear(): number; 
    /** Gets the year using Universal Coordinated Time (UTC). */ 
    getUTCFullYear(): number; 
    /** Gets the month, using local time. */ 
    getMonth(): number; 
    /** Gets the month of a Date object using Universal Coordinated Time (UTC). */ 
    getUTCMonth(): number; 
    /** Gets the day-of-the-month, using local time. */ 
    getDate(): number; 
    /** Gets the day-of-the-month, using Universal Coordinated Time (UTC). */ 
    getUTCDate(): number; 
    /** Gets the day of the week, using local time. */ 
    getDay(): number; 
    /** Gets the day of the week using Universal Coordinated Time (UTC). */ 
    getUTCDay(): number; 
    /** Gets the hours in a date, using local time. */ 
    getHours(): number; 
    /** Gets the hours value in a Date object using Universal Coordinated Time (UTC). */ 
    getUTCHours(): number; 
    /** Gets the minutes of a Date object, using local time. */ 
    getMinutes(): number; 
    /** Gets the minutes of a Date object using Universal Coordinated Time (UTC). */ 
    getUTCMinutes(): number; 
    /** Gets the seconds of a Date object, using local time. */ 
    getSeconds(): number; 
    /** Gets the seconds of a Date object using Universal Coordinated Time (UTC). */ 
    getUTCSeconds(): number; 
    /** Gets the milliseconds of a Date, using local time. */ 
    getMilliseconds(): number; 
    /** Gets the milliseconds of a Date object using Universal Coordinated Time (UTC). */ 
    getUTCMilliseconds(): number; 
    /** Gets the difference in minutes between the time on the local computer and Universal Coordinated Time (UTC). */ 
    getTimezoneOffset(): number; 
    /** 
     * Sets the date and time value in the Date object. 
     * @param time A numeric value representing the number of elapsed milliseconds since midnight, January 1, 1970 GMT. 
     */ 
    setTime(time: number): number; 
    /** 
     * Sets the milliseconds value in the Date object using local time. 
     * @param ms A numeric value equal to the millisecond value. 
     */ 
    setMilliseconds(ms: number): number; 
    /** 
     * Sets the milliseconds value in the Date object using Universal Coordinated Time (UTC). 
     * @param ms A numeric value equal to the millisecond value. 
     */ 
    setUTCMilliseconds(ms: number): number; 

    /** 
     * Sets the seconds value in the Date object using local time. 
     * @param sec A numeric value equal to the seconds value. 
     * @param ms A numeric value equal to the milliseconds value. 
     */ 
    setSeconds(sec: number, ms?: number): number; 
    /** 
     * Sets the seconds value in the Date object using Universal Coordinated Time (UTC). 
     * @param sec A numeric value equal to the seconds value. 
     * @param ms A numeric value equal to the milliseconds value. 
     */ 
    setUTCSeconds(sec: number, ms?: number): number; 
    /** 
     * Sets the minutes value in the Date object using local time. 
     * @param min A numeric value equal to the minutes value. 
     * @param sec A numeric value equal to the seconds value. 
     * @param ms A numeric value equal to the milliseconds value. 
     */ 
    setMinutes(min: number, sec?: number, ms?: number): number; 
    /** 
     * Sets the minutes value in the Date object using Universal Coordinated Time (UTC). 
     * @param min A numeric value equal to the minutes value. 
     * @param sec A numeric value equal to the seconds value. 
     * @param ms A numeric value equal to the milliseconds value. 
     */ 
    setUTCMinutes(min: number, sec?: number, ms?: number): number; 
    /** 
     * Sets the hour value in the Date object using local time. 
     * @param hours A numeric value equal to the hours value. 
     * @param min A numeric value equal to the minutes value. 
     * @param sec A numeric value equal to the seconds value. 
     * @param ms A numeric value equal to the milliseconds value. 
     */ 
    setHours(hours: number, min?: number, sec?: number, ms?: number): number; 
    /** 
     * Sets the hours value in the Date object using Universal Coordinated Time (UTC). 
     * @param hours A numeric value equal to the hours value. 
     * @param min A numeric value equal to the minutes value. 
     * @param sec A numeric value equal to the seconds value. 
     * @param ms A numeric value equal to the milliseconds value. 
     */ 
    setUTCHours(hours: number, min?: number, sec?: number, ms?: number): number; 
    /** 
     * Sets the numeric day-of-the-month value of the Date object using local time. 
     * @param date A numeric value equal to the day of the month. 
     */ 
    setDate(date: number): number; 
    /** 
     * Sets the numeric day of the month in the Date object using Universal Coordinated Time (UTC). 
     * @param date A numeric value equal to the day of the month. 
     */ 
    setUTCDate(date: number): number; 
    /** 
     * Sets the month value in the Date object using local time. 
     * @param month A numeric value equal to the month. The value for January is 0, and other month values follow consecutively. 
     * @param date A numeric value representing the day of the month. If this value is not supplied, the value from a call to the getDate method is used. 
     */ 
    setMonth(month: number, date?: number): number; 
    /** 
     * Sets the month value in the Date object using Universal Coordinated Time (UTC). 
     * @param month A numeric value equal to the month. The value for January is 0, and other month values follow consecutively. 
     * @param date A numeric value representing the day of the month. If it is not supplied, the value from a call to the getUTCDate method is used. 
     */ 
    setUTCMonth(month: number, date?: number): number; 
    /** 
     * Sets the year of the Date object using local time. 
     * @param year A numeric value for the year. 
     * @param month A zero-based numeric value for the month (0 for January, 11 for December). Must be specified if numDate is specified. 
     * @param date A numeric value equal for the day of the month. 
     */ 
    setFullYear(year: number, month?: number, date?: number): number; 
    /** 
     * Sets the year value in the Date object using Universal Coordinated Time (UTC). 
     * @param year A numeric value equal to the year. 
     * @param month A numeric value equal to the month. The value for January is 0, and other month values follow consecutively. Must be supplied if numDate is supplied. 
     * @param date A numeric value equal to the day of the month. 
     */ 
    setUTCFullYear(year: number, month?: number, date?: number): number; 
    /** Returns a date converted to a string using Universal Coordinated Time (UTC). */ 
    toUTCString(): string; 
    /** Returns a date as a string value in ISO format. */ 
    toISOString(): string; 
    /** Used by the JSON.stringify method to enable the transformation of an object's data for JavaScript Object Notation (JSON) serialization. */ 
    toJSON(key?: any): string; 
}