JavaScript Style Guide
Always use the same coding conventions for all your JavaScript projects.
JavaScript Coding Conventions
Coding conventions are style guidelines for programming. They typically cover:
- Naming and declaration rules for variables and functions.
- Rules for the use of white space, indentation, and comments.
- Programming practices and principles
Coding conventions secure quality:
- Improves code readability
- Make code maintenance easier
Coding conventions can be documented rules for teams to follow, or just be your individual coding practice.
This page describes the general JavaScript code conventions used by W3Schools.
You should also read the next chapter “Best Practices”, and learn how to avoid coding pitfalls.
Variable Names
At W3schools we use camelCase for identifier names (variables and functions).
All names start with a letter.
At the bottom of this page, you will find a wider discussion about naming rules.
firstName = "John";
lastName = "Doe";
price = 19.90;
tax = 0.20;
fullPrice = price + (price * tax);
Spaces Around Operators
Always put spaces around operators ( = + – * / ), and after commas:
Examples:
let x = y + z;
const myArray = ["Volvo", "Saab", "Fiat"];
Code Indentation
Always use 2 spaces for indentation of code blocks:
Functions:
function toCelsius(fahrenheit) {
return (5 / 9) * (fahrenheit - 32);
}
Do not use tabs (tabulators) for indentation. Different editors interpret tabs differently.
Statement Rules
General rules for simple statements:
- Always end a simple statement with a semicolon.
Examples:
const cars = ["Volvo", "Saab", "Fiat"];
const person = {
firstName: "John",
lastName: "Doe",
age: 50,
eyeColor: "blue"
};
General rules for complex (compound) statements:
- Put the opening bracket at the end of the first line.
- Use one space before the opening bracket.
- Put the closing bracket on a new line, without leading spaces.
- Do not end a complex statement with a semicolon.
Functions:
function toCelsius(fahrenheit) {
return (5 / 9) * (fahrenheit - 32);
}
Loops:
for (let i = 0; i < 5; i++) {
x += i;
}
Conditionals:
if (time < 20) {
greeting = "Good day";
} else {
greeting = "Good evening";
}
Object Rules
General rules for object definitions:
- Place the opening bracket on the same line as the object name.
- Use colon plus one space between each property and its value.
- Use quotes around string values, not around numeric values.
- Do not add a comma after the last property-value pair.
- Place the closing bracket on a new line, without leading spaces.
- Always end an object definition with a semicolon.
Example
const person = {
firstName: "John",
lastName: "Doe",
age: 50,
eyeColor: "blue"
};
Short objects can be written compressed, on one line, using spaces only between properties, like this:
const person = {firstName:"John", lastName:"Doe", age:50, eyeColor:"blue"};
Line Length < 80
For readability, avoid lines longer than 80 characters.
If a JavaScript statement does not fit on one line, the best place to break it, is after an operator or a comma.
Example
document.getElementById("demo").innerHTML =
"Hello Dolly.";
Naming Conventions
Always use the same naming convention for all your code. For example:
- Variable and function names written as camelCase
- Global variables written in UPPERCASE (We don’t, but it’s quite common)
- Constants (like PI) written in UPPERCASE
Should you use hyp-hens, camelCase, or under_scores in variable names?
This is a question programmers often discuss. The answer depends on who you ask:
Hyphens in HTML and CSS:
HTML5 attributes can start with data- (data-quantity, data-price).
CSS uses hyphens in property-names (font-size).
Hyphens can be mistaken as subtraction attempts. Hyphens are not allowed in JavaScript names.
Underscores:
Many programmers prefer to use underscores (date_of_birth), especially in SQL databases.
Underscores are often used in PHP documentation.
PascalCase:
PascalCase is often preferred by C programmers.
camelCase:
camelCase is used by JavaScript itself, by jQuery, and other JavaScript libraries.
Do not start names with a $ sign. It will put you in conflict with many JavaScript library names.
Loading JavaScript in HTML
Use simple syntax for loading external scripts (the type attribute is not necessary):
<script src="myscript.js"></script>
Accessing HTML Elements
A consequence of using “untidy” HTML styles, might result in JavaScript errors.
These two JavaScript statements will produce different results:
const obj = getElementById("Demo")
const obj = getElementById("demo")
If possible, use the same naming convention (as JavaScript) in HTML.
File Extensions
HTML files should have a .html extension (.htm is allowed).
CSS files should have a .css extension.
JavaScript files should have a .js extension.
Use Lower Case File Names
Most web servers (Apache, Unix) are case sensitive about file names:
london.jpg cannot be accessed as London.jpg.
Other web servers (Microsoft, IIS) are not case sensitive:
london.jpg can be accessed as London.jpg or london.jpg.
If you use a mix of upper and lower case, you have to be extremely consistent.
If you move from a case insensitive, to a case sensitive server, even small errors can break your web site.
To avoid these problems, always use lower case file names (if possible).
Performance
Coding conventions are not used by computers. Most rules have little impact on the execution of programs.
Indentation and extra spaces are not significant in small scripts.
For code in development, readability should be preferred. Larger production scripts should be minified.
45 Responses
levofloxacin 250mg pills levofloxacin 250mg tablet
order generic avodart buy avodart without prescription ondansetron price
spironolactone for sale online purchase fluconazole brand fluconazole 100mg
oral acillin buy erythromycin 500mg generic buy erythromycin online
cheap fildena 50mg methocarbamol ca methocarbamol 500mg sale
order sildenafil 100mg sale estradiol 2mg over the counter estrace 2mg cheap
generic lamictal order vermox without prescription buy tretinoin online cheap
purchase tadalis pills avana order diclofenac 50mg cost
cost accutane 40mg amoxicillin oral purchase azithromycin generic
indomethacin 50mg usa purchase indomethacin for sale cheap trimox 500mg
tadalafil 20mg sale pumps for ed viagra brand
tadalafil comprimГ© acheter 40mg tadalafil en ligne acheter 200mg gГ©nГ©rique viagra en france
deltasone 20mg pills order deltasone generic buy viagra 100mg pills
tadalafil kaufen viagra 100mg kaufen generika sildenafil 100mg generika rezeptfrei kaufen
cheap doxycycline 100mg doxycycline cost order lasix 100mg online
altace 10mg cost order astelin 10 ml generic azelastine 10 ml sale
order catapres pills buy generic tiotropium bromide order tiotropium bromide for sale
generic buspirone phenytoin 100 mg oral buy ditropan 2.5mg sale
terazosin 5mg oral buy leflunomide 10mg sale generic sulfasalazine
fosamax over the counter panadol 500 mg uk pepcid 20mg without prescription
buy benicar sale generic depakote 500mg generic diamox 250mg
tacrolimus buy online urso 300mg price ursodiol canada
isosorbide 20mg without prescription imdur 20mg cost micardis cost
order bupropion generic buy strattera 10mg seroquel drug
buy molnunat 200mg online naproxen 500mg pill lansoprazole for sale online
cost zoloft 100mg order lexapro pill viagra medication
imuran 100mcg sale sildenafil pill viagra 100mg without prescription
cialis 20mg cost tadalafil 40mg cheap viagra us
order cialis 40mg pills cheap cialis online amantadine 100mg ca
naltrexone 50 mg uk abilify sale order abilify 20mg sale
dapsone 100mg uk allegra online aceon 8mg brand
provera 5mg generic microzide 25mg usa periactin online buy
buy provigil stromectol 3mg canada ivermectin 3 mg stromectol
luvox us buy nizoral generic glucotrol 10mg without prescription
buy isotretinoin 10mg generic buy amoxil online prednisone 20mg oral
buy piracetam 800 mg pill buy generic nootropil 800mg sildenafil pills 50mg
order azithromycin generic order generic azithromycin 250mg order neurontin 800mg online
buy tadalafil pills buy viagra 100mg online female viagra sildenafil
cialis uk buy betnovate creams order anafranil 50mg pill
order tadalafil for sale order betnovate cream anafranil 25mg cheap
online free free personals site freetalk45 usa free dating sites
analysis essay help custom essay writing company good essay writing services
magic essay writer help write essay essay help 123
best essay help persuasive essay writer buy essay writing online
essay thesis examples a cruel angel’s thesis sheet music thesis statement informative speech