Зарезервированные слова в Javascript

В JavaScript нельзя использовать следующие зарезервированные слова в качестве имен переменных, функций или меток:

abstract arguments await* boolean
break byte case catch
char class* const continue
debugger default delete do
double else enum* eval
export* extends* false final
finally float for function
goto if implements import*
in instanceof int interface
let* long native new
null package private protected
public return short static
super* switch synchronized this
throw throws transient true
try typeof var void
volatile while with yield

Слова, помеченные знаком *, новые в ECMAScript 5 и 6.

Удаленные зарезервированные слова

Следующие зарезервированные слова были удалены в стандарте ECMAScript 5/6:

abstract boolean byte char
double final float goto
int long native short
synchronized throws transient volatile

Не используйте эти слова в качестве переменных, так как стандарт ECMAScript 5/6 поддерживается не всеми браузерами.

Объекты, свойства и методы в JavaScript

Также следует избегать использования не по прямому назначению имен встроенных объектов, свойств и методов JavaScript:

Array Date eval function
hasOwnProperty Infinity isFinite isNaN
isPrototypeOf length Math NaN
name Number Object prototype
String toString undefined valueOf

Зарезервированные слова Java

JavaScript часто используется вместе с Java. Поэтому также не следует использовать в качестве идентификаторов JavaScript некоторых объектов и свойств Java:

getClass java JavaArray javaClass
JavaObject JavaPackage

Другие зарезервированные слова

JavaScript может использоваться в качестве языка программирования во многих приложениях. Вы также не должны использовать имена объектов и свойств HTML и Window:

alert all anchor anchors
area assign blur button
checkbox clearInterval clearTimeout clientInformation
close closed confirm constructor
crypto decodeURI decodeURIComponent defaultStatus
document element elements embed
embeds encodeURI encodeURIComponent escape
event fileUpload focus form
forms frame innerHeight innerWidth
layer layers link location
mimeTypes navigate navigator frames
frameRate hidden history image
images offscreenBuffering open opener
option outerHeight outerWidth packages
pageXOffset pageYOffset parent parseFloat
parseInt password pkcs11 plugin
prompt propertyIsEnum radio reset
screenX screenY scroll secure
select self setInterval setTimeout
status submit taint text
textarea top unescape untaint
window

Обработчики событий HTML

В дополнение ко всему вышесказанному следует избегать использования имен всех обработчиков событий HTML.

Например:

onblur onclick onerror onfocus
onkeydown onkeypress onkeyup onmouseover
onload onmouseup onmousedown onsubmit