Em JavaScript você não pode usar essas palavras reservadas como variáveis, rótulos ou nomes de funções:
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 |
Palavras marcadas com* são novas no ECMAScript 5 e 6.
Você pode ler mais sobre as diferentes versões de JavaScript no capítulo Versões JS.
As seguintes palavras reservadas foram removidas do padrão ECMAScript 5/6:
abstract | boolean | byte | char |
double | final | float | goto |
int | long | native | short |
synchronized | throws | transient | volatile |
Não use essas palavras como variáveis. ECMAScript 5/6 não tem suporte completo em todos os navegadores.
Você também deve evitar usar o nome de objetos, propriedades e métodos integrados do JavaScript:
Array | Date | eval | function |
hasOwnProperty | Infinity | isFinite | isNaN |
isPrototypeOf | length | Math | NaN |
name | Number | Object | prototype |
String | toString | undefined | valueOf |
JavaScript é frequentemente usado junto com Java. Você deve evitar usar alguns objetos Java e propriedades como identificadores JavaScript:
getClass | java | JavaArray | javaClass |
JavaObject | JavaPackage |
JavaScript pode ser usado como linguagem de programação em muitas aplicações.
Você também deve evitar usar o nome de objetos e propriedades HTML e 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 |
Além disso, você deve evitar usar o nome de todos os manipuladores de eventos HTML.
Exemplos:
onblur | onclick | onerror | onfocus |
onkeydown | onkeypress | onkeyup | onmouseover |
onload | onmouseup | onmousedown | onsubmit |