Об'єкт TypeError позначає помилку, що виникає при використанні значення невідповідного типу.
Синтаксис
new TypeError([message[, fileName[, lineNumber]]])
Параметри
message- Необов'язковий. Зрозумілий людині опис помилки.
fileName- Необов'язковий. Ім'я файлу, код з якого спричинив виняток.
lineNumber- Необов'язковий. Номер рядка в коді, що спричинив виняток.
Опис
TypeError викидається, коли операнд або аргумент, що передається у функцію, несумісний з типом, який очікується цим оператором чи функцією.
Властивості
TypeError.prototype- Дозволяє додавати властивості до об'єктів
TypeError.
Методи
Сам TypeError не має власних методів, але успадковує деякі методи через ланцюжок прототипів.
Екземпляри TypeError
Властивості
TypeError.prototype.constructor- Визначає функцію, яка створила прототип об'єкта.
TypeError.prototype.message- Повідомлення помилки. Хоча ECMA-262 зазначає, що
TypeErrorповинен мати власну властивістьmessage, у SpiderMonkey, він успадковуєError.prototype.message. TypeError.prototype.name- Ім'я помилки. Успадковано від
Error. TypeError.prototype.fileName- Шлях до файлу, що спричинив помилку. Успаковано від
Error. TypeError.prototype.lineNumber- Номер рядка файлу, в якому виникла помилка. Успаковано від
Error. TypeError.prototype.columnNumber- Номер стовпця у рядку, де виникла помилка. Успаковано від
Error. TypeError.prototype.stack- Трасування стеку. Успаковано від
Error.
Методи
Хоча прототип TypeError не містить власних методів, екземпляри TypeError успадковують деякі методи через ланцюжок прототипів.
Приклади
Перехоплення TypeError
try {
null.f();
} catch (e) {
console.log(e instanceof TypeError); // true
console.log(e.message); // "null has no properties"
console.log(e.name); // "TypeError"
console.log(e.fileName); // "Scratchpad/1"
console.log(e.lineNumber); // 2
console.log(e.columnNumber); // 2
console.log(e.stack); // "@Scratchpad/2:2:3\n"
}
Створення TypeError
try {
throw new TypeError('Привіт', "someFile.js", 10);
} catch (e) {
console.log(e instanceof TypeError); // true
console.log(e.message); // "Привіт"
console.log(e.name); // "TypeError"
console.log(e.fileName); // "someFile.js"
console.log(e.lineNumber); // 10
console.log(e.columnNumber); // 0
console.log(e.stack); // "@Scratchpad/2:2:9\n"
}
Специфікації
| Специфікація | Статус | Коментар |
|---|---|---|
| ECMAScript 3rd Edition (ECMA-262) The definition of 'TypeError' in that specification. |
Standard | Початкове визначення. |
| ECMAScript 5.1 (ECMA-262) The definition of 'TypeError' in that specification. |
Standard | |
| ECMAScript 2015 (6th Edition, ECMA-262) The definition of 'TypeError' in that specification. |
Standard | |
| ECMAScript Latest Draft (ECMA-262) The definition of 'TypeError' in that specification. |
Draft |
Сумісність з веб-переглядачами
The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.
Update compatibility data on GitHub
| Desktop | Mobile | Server | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
TypeError | Chrome Full support Yes | Edge Full support Yes | Firefox Full support 1 | IE Full support Yes | Opera Full support Yes | Safari Full support Yes | WebView Android Full support Yes | Chrome Android Full support Yes | Firefox Android Full support 4 | Opera Android Full support Yes | Safari iOS Full support Yes | Samsung Internet Android Full support Yes | nodejs Full support Yes |
Legend
- Full support
- Full support