PedroGeoGISdev
  • Home
  • Linux OS
    • Linux: concepts
    • Linux: basic concepts
    • Linux: Bash
    • Linux: su and sudo
    • Linux: pipes
    • Linux: File System
    • Linux: Virtual Machines

    • Linux: distros
    • Linux Distros: Ubuntu
    • Linux Distros: Mint
    • Linux Distros: Debian
    • Linux Distros: openSuse
    • Linux Distros: Manjaro
    • Linux Distros: Red Hat Enterprise

    • Linux: laboratories
    • Linux Lab#LI01-1: Choose Linux
    • Linux Lab#LI01-2: Install at least three distributions
    • Linux Lab#LI01-3: Adjust user permissions
    • Linux Lab#LI02-1: Export env user with grep and pipe
    • Linux Lab#LI03-1: Manage users and groups
    • Linux Lab#LI03-2: Manage files
    • Linux Lab#LI03-3: Manage software
    • Linux Lab#LI03-4: Manage hardware
    • Linux Lab#LI04-1: Bash scripting, qtool
    • Linux Lab#LI04-2: Bash scripts as terminal tool
    • Linux Lab#LI04-3: Distribute the terminal app

    • Linux readings
    • Linux Resources
  • DevOps
    • What is DevOps
    • DevOps: Introduction
    • DevOps: Agile and Microservices
    • Infrastructure as code (IaC)
    • Immutable Infrastructure
    • Software Lifecycle

    • Documentation
    • How to document: Quarto and Obsidian

    • Network protocols
    • Network: Basics
    • Network: Client-server
    • Network Protocols
    • Network: DNS
    • Network: API Rest
    • Network: gRPC
    • Network: Websocket
    • Network: SMTP
    • Network: Ping
    • Network: UDP
    • Network: webhook
    • Network: SOAP
    • Network: graphQL

    • Version Control
    • Git
    • GitHub
    • Idea and GitHub 2023
    • Git and GitHub 2023 CLI

    • IDEs
    • IDE: Visual Code
    • IDE: IntellJIdea

    • DevOps tools
    • Amazon Web Services AWS
    • Docker
    • Jenkins pipelines
    • Kubernetes k8s
    • Digital Ocean
    • Nagios
    • Ansible

    • DevOps Laboratories
    • Lab 1: chat App
    • Lab 2: Spring Boot AWS AEB manually
    • Lab 3: Spring Boot and AWS S3 publisher
    • Lab 4: Spring Boot Docker/Jenkins
    • Lab 5: k8s on Digital Ocean
    • Lab 6: Spring Boot AWS codecommit

    • DevOps readings
    • DevOps Resources
  • MarkUp
    • MarkUp Languages
    • Introduction Markup
    • HTML Markup
    • Markdown Markup
    • Markdown and HTML working together, good idea?

    • Quarto Markdown
    • Quarto Markdown: basics
    • Quarto Markdown: creating
    • Quarto Markdown: publishing
    • Quarto Markdown: code & data
    • Quarto Markdown: api rest call
    • Quarto Markdown: OJS Cells
    • Quarto Markdown: cheat-sheet

    • Styling: CSS
    • Cascade Style Sheet
    • Cascade Style Sheet: Box Model and Containers
    • CSS: W3.css

    • MarkUp Languages Laboratories
    • Lab#MD01-1: Create and publish by Quarto

    • MarkUp Languages readings
    • MarkUp Languages Resources
  • Java SE
    • What is Java SE
    • Java Standard Edition: Basics
    • Java Standard Edition: Principles
    • Java MOOC Helsinki
    • Java MOOC Helsinki Syllabus

    • Java Create Project
    • Java SE: Maven
    • Java SE: Create Maven Project
    • Java SE: Project push GitHub
    • Java SE: JUnit and TDD

    • Java Concepts
    • Java SE: Class and Objects
    • Java SE: Scope
    • Java SE: static modifier
    • Java SE: Coupling and DDD
    • Java SE: Packages
    • Java SE: Abstract/Interface
    • Java SE: Java 8

    • Java Principles
    • Java SE: Encapsulation
    • Java SE: Abstraction
    • Java SE: Inherence
    • Java SE: Polymorphism

    • Java Design Patterns
    • Java Patterns: UML
    • Java Patterns: Types
    • Singleton
    • Factory
    • Abstract Factory
    • Builder
    • Facade
    • Bridge
    • Decorator
    • Composite
    • Observer
    • Strategy
    • State
    • Commander

    • Java SE Laboratories
    • Lab#SE00-1: Maven Person
    • Lab#SE00-2: Maven Clinic
    • Lab#SE00-3: Library Model
    • Lab#SE00-4: Abstract/Interface Human
    • Lab#SE01-1: Maven/Gradle Person and Account
    • Lab#SE01-2: Maven/Gradle Person and Account stored in JSON
    • Lab#SE02-1: Movie/Review, Model
    • Lab#SE02-2: Movie/Review, CRUD Operations
    • Lab#SE02-3: Movie/Review, factory
    • Lab#SE02-4: Movie/Review, interactivity and coupling
    • Lab#SE02-5: Movie/Review, simulate interactivity by console
    • Lab#SE03-1: Library/Book, Core-Model
    • Lab#SE03-2: Library/Book, Sprint Zero
    • Lab#SE03-3: Library/Book, Expand Model
    • Lab#SE04-1: healthyFood Restaurant, Core Model

    • Java SE readings
    • Java SE Resources
  • Python
    • Python Basics
    • Python: Basic Concepts
    • Python: Numbers
    • Python: Strings
    • Python: Conditionals
    • Python: Lists and Loops
    • Python: Nested Loops
    • Python: Tuples
    • Python: Sets
    • Python: Dictionaries
    • Python: Functions
    • Python: Higher-order Functions
    • Python: Variable Scope
    • Python: Variable Assigment
    • Python: None keyword in Python
    • Python: Object Oriented Programming (OOP)
    • Python: Inheritance and Polymorphism
    • Python: Encapsulation
    • Python: Abstraction
    • Python: Cheat-Sheets
  • JavaScript
    • JavaScript Basics
    • JavaScript: Fundamentals
    • JavaScript: Data Types
    • JavaScript: Variables
    • JavaScript: Operators
    • JavaScript: Conditionals
    • JavaScript: Loops
    • JavaScript: Functions
    • JavaScript: Arrays
    • JavaScript: Objects

    • React Framework

    • ReactJS: Principles
    • React JS: Introduction
    • React JS: render virtual DOM
    • React JS: Create a React project
    • React JS: Components
    • React JS: JSX
    • React JS: props and state

    • JavaScript: web scripting
    • JavaScript: basics
    • JavaScript: functions
    • JavaScript: objects
    • JavaScript: variables
    • JavaScript: flux control

    • ES6: ECMAScript 6
    • React JS ES6: arrow functions
    • React JS ES6: import modules
    • React JS ES6: array, data and key
    • React JS ES6: destructuring
    • React JS ES6: spread operator

    • ReacJS 18: Hooks
    • React JS: Rules of Hooks
    • ReactJS: useState
    • React JS: useReducer
    • React JS: useRef
    • React JS: useEffect
    • React JS: useContext
    • ReactJS: useMemo
    • ReactJS: custom hooks

    • ReactJS: Designing an App
    • React JS App: async
    • React JS App: events
    • React JS App: router
    • React JS App: conditional render
    • React JS App: styling

    • React JS: Laboratories
    • Lab#RE01-1: API Rest Axios
    • Lab#RE02-1: Router & Hooks
    • Lab#RE03-1: to-do app
    • Lab#RE03-2: HighCharts
    • Lab#RE03-3: API Rest Mono
    • Lab#RE03-4: API Rest Domains
    • Lab#RE03-5: data management
    • Lab#RE04-1: todo & server
    • Lab#RE04-2: Spring Boot & ReactJS
    • Lab#RE05-1: chat & websockets
    • Lab#RE05-2: chat: backend
    • Lab#RE05-3: chat & AWS
    • Lab#RE05-4: chat: test ws AWS
    • Lab#RE05-5: chat & front
    • Lab#RE05-6: chat & ws: front
    • Lab#RE06-1: healthyFood Restaurant
    • Lab#RE06-1-PR: create a pull request
    • Lab#RE07-1: traffic lights simulation

    • React JS readings
    • ReactJS Resources
  • Backend
    • Spring Legacy
    • Spring Framework
    • Spring MVC
    • Springs Servlets

    • Spring Boot Basics
    • Spring Boot: fundamentals
    • Spring Boot: create a Project
    • Spring Boot: H2 DB and Thymeleaf
    • Spring Boot: cycle

    • Spring Boot Concepts
    • Spring Boot: Dependency Injection
    • Spring Boot: Annotations
    • Spring Boot: Controller
    • Spring Boot: View
    • Spring Boot: Thymeleaf
    • Spring Boot: Vaadin Flow
    • Spring Boot: Vaadin Hilla
    • Spring Boot: Model
    • Spring Boot: Rest
    • Spring Boot: Data & DB
    • Spring Boot: JPA & DI
    • Spring Boot: JPA Mappings
    • Spring Boot: JPA Relationships
    • Spring Boot: JPA Queries
    • Spring Boot: JPA Inherence
    • Spring Boot: Scaling

    • Spring Boot Laboratories
    • Lab#SB00-1: Library UML
    • Lab#SB00-2: CRUD User
    • Lab#SB00-3: LibraryManagement
    • Lab#SB00-4: API Rest
    • Lab#SB00-5: Rest & JPA-H2
    • Lab#SB00-6: Rest & MongoDB
    • Lab#SB00-7: Styling
    • Lab#SB01-1: DataBase
    • Lab#SB02-1: JPA Relationships
    • Lab#SB03-1: APIs & cloud
    • Lab#SB04-1: JPA Inherence
    • Lab#SB05-1: API Rest
    • Lab#SB06-1: employeeCourse
    • Lab#SB07-1: monitor Book
    • Lab#SB08-1: Restaurant UML
    • Lab#SB08-2: Vaadin
    • Lab#SB08-3: H2 and API Rest
    • Lab#SB08-4: JPA
    • Lab#SB08-5: Test API Rest
    • Lab#SB09-1: SpringIO Conference

    • Spring Boot readings
    • Spring Boot Resources
  • Learning
    • Vocabulary
    • General Vocabulary
    • SCRUM Vocabulary
    • DevOps Vocabulary
    • Java SE Vocabulay
    • Spring Boot Vocabulary
    • DataBase Vocabulary
    • ReactJS Vocabulary
    • Web Vocabulary

    • Learning
    • Useful Questions
    • Learning: tips
    • Writing
    • Taking Notes
    • Comments
    • Document
    • Auto-Evaluate

    • Books & Articles
    • Books
    • Articles

    • What is SCRUM
    • SCRUM Agile Methodology
    • Agile Manifesto & Values
    • SCRUM Guide

    • Scrum Steps
    • Meetings, Impediments and Iterations
    • User stories, Tasks and Habits
    • Delivering Value & Communication
    • ScrumMaster, how it works
    • Mindset, the key to everything
    • Product Owner, how it works
    • Managing Time & Mind
    • Team & the Specialist
    • Albertus’ Dilemma
    • Before SCRUM
    • Team Dynamics
    • Emotions and Thoughts
    • Decision Making and Intuition
    • Beyond SCRUM
    • Balances, atmosphere and tools

    • Resources
    • SCRUM Resources
  • QGIS
    • QGIS basics
    • QGIS: basic concepts

    • QGIS laboratories
    • QGIS Laboratory 1: Introduction to Open Source GIS
  • ArcGIS Pro
    • ArcGIS Pro basics
    • ArcGIS Pro: basic concepts

    • ArcGIS Pro laboratories
    • ArcGIS Pro Laboratory 1: Getting Started
  • Bookmarks
    • Online Resources
    • Online Resources
  • About
    • About me and this site
    • About me
    • About this site
    • About images credit
  • Maps
  • Featured Projects
    • ✈️ Flight tracker
    • 🧑 People tracker
    • 🚗 Renting Car
    • Email
    • GitHub
    • LinkedIn
  1. JavaScript Basics
  2. JavaScript: Variables
  • JavaScript

  • JavaScript Basics
    • JavaScript: Fundamentals
    • JavaScript: Data Types
    • JavaScript: Variables
    • JavaScript: Operators
    • JavaScript: Conditionals
    • JavaScript: Loops
    • JavaScript: Functions
    • JavaScript: Arrays
    • JavaScript: Objects

  • React Framework

  • ReactJS: Principles
    • React JS: Introduction
    • React JS: render virtual DOM
    • React JS: Create a React project
    • React JS: Components
    • React JS: JSX
    • React JS: props and state

  • JavaScript: web scripting
    • JavaScript: basics
    • JavaScript: functions
    • JavaScript: objects
    • JavaScript: variables
    • JavaScript: flux control

  • ES6: ECMAScript 6
    • React JS ES6: arrow functions
    • React JS ES6: import modules
    • React JS ES6: array, data and key
    • React JS ES6: destructuring
    • React JS ES6: spread operator

  • ReacJS 18: Hooks
    • React JS: Rules of Hooks
    • ReactJS: useState
    • React JS: useReducer
    • React JS: useRef
    • React JS: useEffect
    • React JS: useContext
    • ReactJS: useMemo
    • ReactJS: custom hooks

  • ReactJS: Designing an App
    • React JS App: async
    • React JS App: events
    • React JS App: router
    • React JS App: conditional render
    • React JS App: styling

  • React JS: Laboratories
    • Lab#RE01-1: API Rest Axios

    • Lab#RE02-1: Router & Hooks

    • Lab#RE03-1: to-do app
    • Lab#RE03-2: HighCharts
    • Lab#RE03-3: API Rest Mono
    • Lab#RE03-4: API Rest Domains
    • Lab#RE03-5: data management

    • Lab#RE04-1: todo & server
    • Lab#RE04-2: Spring Boot & ReactJS

    • Lab#RE05-1: chat & websockets
    • Lab#RE05-2: chat: backend
    • Lab#RE05-3: chat & AWS
    • Lab#RE05-4: chat: test ws AWS
    • Lab#RE05-5: chat & front
    • Lab#RE05-6: chat & ws: front

    • Lab#RE06-1: healthyFood Restaurant
    • Lab#RE06-1-PR: create a pull request

    • Lab#RE07-1: traffic lights simulation

  • React JS readings
    • ReactJS Resources

On this page

  • 1 Overview
  • 2 A Variable
    • 2.1 Combined Declaration and Assignment
    • 2.2 Multiple Variables
    • 2.3 Variable Reassignment
    • 2.4 Copying Variables
  • 3 Variable Naming
    • 3.1 Valid Names
    • 3.2 camelCase Convention
    • 3.3 Invalid Names
    • 3.4 Case Sensitivity
    • 3.5 Reserved Words
  • 4 Constants
    • 4.1 When to Use const
    • 4.2 Uppercase Constants
    • 4.3 Runtime Constants
  • 5 var (Legacy)
  • 6 Variable Scope
    • 6.1 Block Scope (let and const)
    • 6.2 Function Scope
    • 6.3 Global Scope
  • 7 Best Practices
  • 8 Examples
    • 8.1 Example 1: User Information
    • 8.2 Example 2: Constants
    • 8.3 Example 3: Variable Reassignment
    • 8.4 Example 4: Swapping Variables
  • 9 Summary
  • Edit this page
  • View source
  • Report an issue
  1. JavaScript Basics
  2. JavaScript: Variables

JavaScript: Variables

JavaScript Variables

javascript
variables
JavaScript Variables - Declaration, Naming, and Constants
Author

Pedro GeoGIS

Published

Monday, January 13, 2025

Modified

Monday, October 13, 2025

1 Overview

📘 Variables

Variables are named storage locations for data in JavaScript. They allow you to store, retrieve, and manipulate values throughout your program. JavaScript uses let, const, and var (legacy) keywords to declare variables. Variables in JavaScript are dynamically typed, meaning they can hold values of any type and can be reassigned to different types during execution.


2 A Variable

A variable is a “named storage” for data. We can use variables to store information like user data, shopping cart items, messages, and much more.

To create a variable in JavaScript, use the let keyword:

let message;

Now we can put data into it using the assignment operator =:

let message;
message = 'Hello'; // store the string 'Hello' in the variable

The string is now saved into the memory area associated with the variable. We can access it using the variable name:

let message;
message = 'Hello!';
alert(message); // shows the variable content: Hello!

2.1 Combined Declaration and Assignment

To be concise, we can combine the variable declaration and assignment into a single line:

let message = 'Hello!'; // define the variable and assign the value
alert(message); // Hello!

2.2 Multiple Variables

We can declare multiple variables in one line:

let user = 'John', age = 25, message = 'Hello';

However, for better readability, it’s recommended to use a single line per variable:

let user = 'John';
let age = 25;
let message = 'Hello';

2.3 Variable Reassignment

We can change the value of a variable at any time:

let message = 'Hello';
message = 'World'; // value changed
alert(message); // World

When the value is changed, the old data is removed from the variable:

let message = 'Hello!';
message = 'World!'; // 'Hello!' is replaced with 'World!'

2.4 Copying Variables

We can also copy data from one variable to another:

let hello = 'Hello world!';
let message;

message = hello; // copy 'Hello world' from hello into message
alert(hello);    // Hello world!
alert(message);  // Hello world!

3 Variable Naming

There are two limitations on variable names in JavaScript:

  1. The name must contain only letters, digits, or the symbols $ and **_**
  2. The first character must not be a digit

3.1 Valid Names

Examples of valid variable names:

let userName;
let test123;
let $ = 1;
let _ = 2;
let _privateVar = 'secret';
let $jquery = 'library';

3.2 camelCase Convention

When the name contains multiple words, camelCase is commonly used. Words go one after another, each word except the first starting with a capital letter:

let myVeryLongName = 'value';
let firstName = 'John';
let lastName = 'Doe';
let isUserLoggedIn = true;

3.3 Invalid Names

Examples of incorrect variable names:

let 1a;        // cannot start with a digit
let my-name;   // hyphens '-' aren't allowed
let my name;   // spaces aren't allowed

3.4 Case Sensitivity

Variable names are case-sensitive. Variables named apple and APPLE are two different variables:

let apple = 'fruit';
let APPLE = 'FRUIT';
alert(apple);  // fruit
alert(APPLE);  // FRUIT

3.5 Reserved Words

There is a list of reserved words that cannot be used as variable names because they are used by the language itself.

Examples: let, class, return, function, if, else, for, while, etc.

let let = 5;      // ERROR: can't name a variable "let"
let return = 5;   // ERROR: can't name it "return"
let class = 'A';  // ERROR: "class" is reserved

4 Constants

To declare a constant (unchanging) variable, use const instead of let:

const myBirthday = '18.04.1982';

Variables declared using const are called “constants”. They cannot be reassigned. An attempt to do so would cause an error:

const myBirthday = '18.04.1982';
myBirthday = '01.01.2001'; // ERROR: can't reassign the constant!

4.1 When to Use const

Use const when you’re sure that a variable will never change. This: - Guarantees the value won’t be modified - Communicates intent to other developers - Helps prevent bugs from accidental reassignment

const PI = 3.14159;
const MAX_USERS = 100;
const API_URL = 'https://api.example.com';

4.2 Uppercase Constants

There is a widespread practice to use constants as aliases for difficult-to-remember values that are known before execution.

Such constants are named using CAPITAL LETTERS and UNDERSCORES:

const COLOR_RED = "#F00";
const COLOR_GREEN = "#0F0";
const COLOR_BLUE = "#00F";
const COLOR_ORANGE = "#FF7F00";

// When we need to pick a color
let color = COLOR_ORANGE;
alert(color); // #FF7F00

Benefits: - COLOR_ORANGE is easier to remember than "#FF7F00" - Less prone to typos - More meaningful when reading code


4.3 Runtime Constants

Constants calculated at runtime but not changed after assignment use normal naming:

const pageLoadTime = calculateLoadTime(); // calculated at runtime
const userAge = 2025 - birthYear;         // calculated, but constant

Rule of thumb: Capital-named constants are only used as aliases for “hard-coded” values known before execution.


5 var (Legacy)

In older scripts, you may find another keyword: var instead of let:

var message = 'Hello';

The var keyword is almost the same as let, but it declares a variable in the “old-school” way with some important differences:

  • var has no block scope (function-scoped or global)
  • var declarations are processed at function start (hoisting)
  • var allows redeclaration

Recommendation: Use let and const in modern code. Avoid var.


6 Variable Scope

6.1 Block Scope (let and const)

Variables declared with let and const are block-scoped:

{
  let message = 'Hello';
  alert(message); // Hello
}

alert(message); // ERROR: message is not defined

6.2 Function Scope

Variables declared inside a function are only accessible within that function:

function showMessage() {
  let message = 'Hello';
  alert(message);
}

showMessage(); // Hello
alert(message); // ERROR: message is not defined

6.3 Global Scope

Variables declared outside any function or block are global:

let userName = 'John';

function showUser() {
  alert(userName); // can access global variable
}

showUser(); // John

7 Best Practices

  1. Use descriptive names: userName is better than u or data
  2. Use camelCase: firstName, isLoggedIn, getUserData
  3. Prefer const: Use const by default, let only when reassignment is needed
  4. Avoid var: Use modern let and const instead
  5. One variable per line: Easier to read and maintain
  6. Use UPPERCASE for hard-coded constants: MAX_SIZE, API_KEY

8 Examples

8.1 Example 1: User Information

let firstName = 'John';
let lastName = 'Doe';
let age = 30;
let isStudent = false;

console.log(`${firstName} ${lastName} is ${age} years old.`);
// Output: John Doe is 30 years old.

8.2 Example 2: Constants

const SECONDS_IN_MINUTE = 60;
const MINUTES_IN_HOUR = 60;
const HOURS_IN_DAY = 24;

const SECONDS_IN_DAY = SECONDS_IN_MINUTE * MINUTES_IN_HOUR * HOURS_IN_DAY;
console.log(`There are ${SECONDS_IN_DAY} seconds in a day.`);
// Output: There are 86400 seconds in a day.

8.3 Example 3: Variable Reassignment

let counter = 0;
console.log(counter); // 0

counter = counter + 1;
console.log(counter); // 1

counter = counter + 5;
console.log(counter); // 6

8.4 Example 4: Swapping Variables

let a = 5;
let b = 10;

console.log(`Before swap: a = ${a}, b = ${b}`);

// Swap using a temporary variable
let temp = a;
a = b;
b = temp;

console.log(`After swap: a = ${a}, b = ${b}`);
// Output: After swap: a = 10, b = 5

9 Summary

  • Variables are named storage for data
  • Use let to declare variables that can be reassigned
  • Use const to declare constants that cannot be reassigned
  • Variable names must start with a letter, $, or _
  • Use camelCase for variable names
  • Use UPPERCASE_WITH_UNDERSCORES for hard-coded constants
  • Avoid using var in modern JavaScript
  • Variables are case-sensitive
  • Cannot use reserved words as variable names
Back to top
JavaScript: Data Types
JavaScript: Operators

License: CC0 1.0 Universal

Per aspera, ad astra

  • Edit this page
  • View source
  • Report an issue