--- title: Symbol.toPrimitive slug: Web/JavaScript/Reference/Global_Objects/Symbol/toPrimitive translation_of: Web/JavaScript/Reference/Global_Objects/Symbol/toPrimitive ---
Symbol.toPrimitive
是一个内置的 Symbol 值,它是作为对象的函数值属性存在的,当一个对象转换为对应的原始值时,会调用此函数。
在 Symbol.toPrimitive
属性(用作函数值)的帮助下,一个对象可被转换为原始值。该函数被调用时,会被传递一个字符串参数 hint
,表示要转换到的原始值的预期类型。 hint
参数的取值是 "number"
、"string"
和 "default"
中的任意一个。
{{js_property_attributes(0,0,0)}}
下面的例子展示了, Symbol.toPrimitive
属性是如何干扰一个对象转换为原始值时输出的结果的。
// 一个没有提供 Symbol.toPrimitive 属性的对象,参与运算时的输出结果 var obj1 = {}; console.log(+obj1); // NaN console.log(`${obj1}`); // "[object Object]" console.log(obj1 + ""); // "[object Object]" // 接下面声明一个对象,手动赋予了 Symbol.toPrimitive 属性,再来查看输出结果 var obj2 = { [Symbol.toPrimitive](hint) { if (hint == "number") { return 10; } if (hint == "string") { return "hello"; } return true; } }; console.log(+obj2); // 10 -- hint 参数值是 "number" console.log(`${obj2}`); // "hello" -- hint 参数值是 "string" console.log(obj2 + ""); // "true" -- hint 参数值是 "default"
规范 | 状态 | 注释 |
---|---|---|
{{SpecName('ES6', '#sec-symbol.toprimitive', 'Symbol.toPrimitive')}} | {{Spec2('ES6')}} | 原始定义 |
{{SpecName('ESDraft', '#sec-symbol.toprimitive', 'Symbol.toPrimitive')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.Symbol.toPrimitive")}}