--- title: 'Date.prototype[@@toPrimitive]' slug: Web/JavaScript/Reference/Global_Objects/Date/@@toPrimitive translation_of: Web/JavaScript/Reference/Global_Objects/Date/@@toPrimitive ---
{{JSRef}}

[@@toPrimitive]() 方法可以转换一个 Date 对象到一个原始值。

用法

Date()[Symbol.toPrimitive](hint);

返回值

给出的 {{jsxref("Date")}} 的原始值。根据传入参数的不同,可以返回 string 或 number 类型。

说明

{{jsxref("Date")}} 对象的 [@@toPrimitive]() 方法可以返回一个原始值,或是 string,或是number。

如果 hint"string""default"[@@toPrimitive]() 将会调用 {{jsxref("Object.prototype.toString()", "toString")}}。如果 toString 属性不存在,则调用 {{jsxref("Object.prototype.valueOf()", "valueOf")}}。如果 valueOf 也不存在,则抛出一个{{jsxref("TypeError")}}。

如果 hint"number"[@@toPrimitive]() 会首先尝试 valueOf,若失败再尝试 toString

当期望一个原始值却收到一个对象时,JavaScript 可以自动的调用 [@@toPrimitive]() 方法来将一个对象转化成原始值,所以你很少会需要自己调用这个方法。

Specifications

Specification Status Comment
{{SpecName('ES6', '#sec-date.prototype-@@toprimitive', 'Date.prototype.@@toPrimitive')}} {{Spec2('ES6')}} Initial definition.
{{SpecName('ESDraft', '#sec-date.prototype-@@toprimitive', 'Date.prototype.@@toPrimitive')}} {{Spec2('ESDraft')}}  

Browser compatibility

{{Compat("javascript.builtins.Date.@@toPrimitive")}}

See also