--- title: Object.prototype.toString() slug: Web/JavaScript/Reference/Global_Objects/Object/toString tags: - JavaScript - Method - Object - Prototype translation_of: Web/JavaScript/Reference/Global_Objects/Object/toString ---
Метод toString()
возвращает строку, представляющую объект.
{{EmbedInteractiveExample("pages/js/object-prototype-tostring.html")}}
obj.toString()
Строка, представляющая объект.
Каждый объект имеет метод toString()
, автоматически вызывающийся, когда объект должен быть представлен в виде текстового значения или когда объект участвует в выражении, где ожидается строка. По умолчанию, метод toString()
наследуется каждым объектом, произошедшим от объекта {{jsxref("Global_Objects/Object", "Object")}}. Если этот метод не переопределён в пользовательском объекте, toString()
возвращает строку вида "[object тип]", где тип
— это тип объекта. Это иллюстрирует следующий код:
var o = new Object(); o.toString(); // вернёт [object Object]
Примечание: начиная с JavaScript 1.8.5, метод toString()
, вызванный на {{jsxref("Global_Objects/null", "null")}}, возвращает строку [object Null]
, а вызванный для {{jsxref("Global_Objects/undefined", "undefined")}}, возвращает строку [object Undefined]
, как определено в 5-м издании ECMAScript и последующих исправлениях. Смотрите пример {{anch("Using_toString_to_detect_object_type", "использование метода toString() для определения типа объекта")}}.
toString
по умолчаниюВы можете создать функцию, которая будет вызываться вместо метода toString()
по умолчанию. Метод toString()
не принимает аргументов и должен возвращать строку. Создаваемый вами метод toString()
может возвращать любую строку, какую вы захотите, но он будет наиболее полезным, если будет возвращать информацию об объекте.
Следующий код определяет объект Dog
и создаёт theDog
, объект типа Dog
:
function Dog(name, breed, color, sex) { this.name = name; this.breed = breed; this.color = color; this.sex = sex; } theDog = new Dog('Болтушка', 'лабрадор', 'шоколадный', 'девочка');
Если вы вызовете метод toString()
на этом пользовательском объекте, он вернёт значение по умолчанию, унаследованное от {{jsxref("Global_Objects/Object", "Object")}}:
theDog.toString(); // вернёт [object Object]
Следующий код создаёт и присваивает метод dogToString()
, переопределяющий метод toString()
по умолчанию. Эта функция генерирует строку, содержащую кличку, породу, цвет и пол объекта, в форме "свойство = значение;
".
Dog.prototype.toString = function dogToString() { var ret = 'Собачка ' + this.name + ' - ' + this.sex + ', ' + this.color + ' ' + this.breed; return ret; }
или
Dog.prototype.toString = function dogToString() { return `Dog ${this.name} is a ${this.sex} ${this.color} ${this.breed}`; }
После объявления этого метода, при любом использовании переменной theDog
в строковом контексте, JavaScript будет автоматически вызывать функцию dogToString()
, возвращающую следующую строку:
Собачка Болтушка - девочка, шоколадный лабрадор
toString
для определения типа объектаМетод toString()
можно использовать с любым объектом для получения его класса. Для использования метода Object.prototype.toString()
с любым объектом, вам необходимо вызвать на нём функции {{jsxref("Function.prototype.call()")}} или {{jsxref("Function.prototype.apply()")}}, передав объект, который вы хотите исследовать, первым параметром thisArg
.
var toString = Object.prototype.toString; toString.call(new Date); // [object Date] toString.call(new String); // [object String] toString.call(Math); // [object Math] // Начиная с JavaScript 1.8.5 toString.call(undefined); // [object Undefined] toString.call(null); // [object Null]
Спецификация | Статус | Комментарии |
---|---|---|
{{SpecName('ESDraft', '#sec-object.prototype.tostring', 'Object.prototype.toString')}} | {{Spec2('ESDraft')}} | |
{{SpecName('ES6', '#sec-object.prototype.tostring', 'Object.prototype.toString')}} | {{Spec2('ES6')}} | |
{{SpecName('ES5.1', '#sec-15.2.4.2', 'Object.prototype.toString')}} | {{Spec2('ES5.1')}} | Вызов метода на {{jsxref("Global_Objects/null", "null")}} вернёт [object Null] , а на {{jsxref("Global_Objects/undefined", "undefined")}} — [object Undefined] |
{{SpecName('ES1')}} | {{Spec2('ES1')}} | Изначальное определение. Реализована в JavaScript 1.0. |