--- title: Symbol.prototype.valueOf() slug: Web/JavaScript/Reference/Global_Objects/Symbol/valueOf translation_of: Web/JavaScript/Reference/Global_Objects/Symbol/valueOf ---
valueOf()
方法返回当前 symbol 对象所包含的 symbol 原始值。
symbol.valueOf();
在 JavaScript 中,虽然大多数类型的对象在某些操作下都会自动的隐式调用自身的 valueOf()
方法或者 toString()
方法来将自己转换成一个原始值,但 symbol 对象不会这么干,symbol 对象无法隐式转换成对应的原始值:
Object(Symbol("foo")) + "bar"; // TypeError: can't convert symbol object to primitive // 无法隐式的调用 valueOf() 方法 Object(Symbol("foo")).valueOf() + "bar"; // TypeError: can't convert symbol to string // 手动调用 valueOf() 方法,虽然转换成了原始值,但 symbol 原始值不能转换为字符串 Object(Symbol("foo")).toString() + "bar"; // "Symbol(foo)bar",需要手动调用 toString() 方法才行
Specification | Status | Comment |
---|---|---|
{{SpecName('ES6', '#sec-symbol.prototype.valueof', 'Symbol.prototype.valueOf')}} | {{Spec2('ES6')}} | Initial definition. |
{{ CompatibilityTable() }}
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
Basic support | {{ CompatVersionUnknown() }} | {{ CompatGeckoDesktop("33.0") }} | {{ CompatNo() }} | {{ CompatNo() }} | {{ CompatNo() }} |
Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Basic support | {{ CompatVersionUnknown() }} | {{ CompatVersionUnknown() }} | {{ CompatGeckoMobile("33.0") }} | {{ CompatNo() }} | {{ CompatNo() }} | {{ CompatNo() }} |