Introduction to objects

Understanding objects, creating and accessing object properties, and working with object methods.

Learning Goals

At the end of this Tutorial, you will be able to:

  • Create an object with a name and curly braces {}.
  • Add, modify and delete properties within an object.
  • Access object properties using dot . notation.
  • Test for object type with the typeof operator.
  • Destructure properties from an object to variables.

Download a new workfile on your computer as described at the link below.

📄  JavaScript objects: Exercises

Storing spreadsheet-type data as objects

Often, you will want to work with sets of related data about a particular person or thing. Consider the spreadsheet below. For each person, there are four items of data.

screenshot

In JavaScript, you can use an object to store such related data. Each item in an object is called a property, and has two parts: a key (name or label) and a value.

screennshot

In the above example, the object has four properties, each one with a property name (such as Age) and a property value (such as 23).

Naming your objects

Object names follow the usual JavaScript rules: they are case-sensitive and cannot contain spaces or the dash (-) character. Here are two tips:

  • Begin your object names with obj, such as objUser and objProduct.
  • Use singular nouns for object names, such as objProduct rather than objProducts.

Creating an object with {} notation

You can create an object using an object name and curly braces {}. This is called object literal notation.

Copy the following code to your objects.html workfile.

// Declaring and populating an object
const objUser = {
    firstName: "Luis", // string
    lastName: "Martinez", // string
    age: 32, // number
    isActive: true // boolean
};

console.log(objUser);

As you can see, the colon : character separates a key from its value. And the comma , character signals the end of each key-value pair.

screenshot

Your web browser JavaScript console should now look similar to the following.

screenshot

To prevent your objects from being accidentally overwritten, declare them with const rather than let. You can still modify individual properties later if needed.

Displaying a property's value by its key

You can use the key of a property to display its value.

// === Displaying a property inside an object by its key ===

console.log(`User's first name: ${objUser.firstName}`);
console.log(`User's last name:  ${objUser.lastName}`);
console.log(`User's age: ${objUser.age}`);
console.log(`User active?: ${objUser.isActive}`);

This should output the following to your console.

screenshot

Working with the properties of an object

You can add a new property (key-value pair) to an object, change the value of a property, and delete a property from an object.

// === Working with the properties of an object ===

// Declaring and populating new object
const objCar = {
    make: "Toyota",
    model: "Camry",
    year: 2023,
};
console.log("Original object"); 
console.log(objCar);

// Adding two new properties (key-value) pairs to the object
objCar.color = "Blue";   
objCar.isElectric = false;  
console.log("Added two new properties"); 
console.log(objCar);

// Deleting a property from an object
delete objCar.isElectric;
console.log("Removed a property"); 
console.log(objCar);

// Updating the value within two properties
objCar.color = "Red";   
objCar.year = 2012;   
console.log("Updated two property values"); 
console.log(objCar);

Here is the console output of the original object, followed by the various property changes.

screenshot

Creating an empty object

You can create an object without entering keys or values. See below.

// === Creating an empty object and later adding keys-values ===

// Create empty object
const objPerson = {};
console.log(objPerson.length === 0); // true
                
// Add keys and values to empty object
objPerson.firstName = "Emma";
objPerson.lastName = "Smith";
console.log(objPerson.length === 0); // false

console.log(objPerson);
// {firstName: "Emma", lastName: "Smith"}

Object destructuring

Object destructuring allows you to extract properties from objects and assign them to variables.

// === Object destructuring ===

// Without destructuring
const userFirstName = objUser.firstName;
const userLastName = objUser.lastName;

// With destructuring
const { firstName, lastName } = objUser;
console.log(`User name: ${firstName} ${lastName}`);

// Destructuring with different variable names
const { price: productPrice, name: productName } = objProduct;
console.log(`${productName} costs ${productPrice}`);

Try it yourself

In your workfile...

---

Create an object called objBook with the following properties and output each property to the console:
  title (string)
 author (string)
 year (number)
 isAvailable (boolean)

---

Create an object called objComputer with properties for brand, model, and price. Then:

- Add a new property called inStock

- Update the price

- Delete the model property

- Output the object to the console after each change

---

Create an object called objProduct with properties for name, price, and category. Use object destructuring to:

- Extract all properties to individual variables

- Extract only name and price, with price renamed to productPrice

- Output the extracted values

More learning resources

Tutorial Quiz

  Take the test

Tutorial Podcast

Sample AI prompts

Write a series of code examples that show different ways to manipulate object properties - adding, updating, and deleting properties. Include error cases that might occur when working with const objects and explain why they happen.
Create a step-by-step explanation of how object destructuring works in JavaScript, with examples comparing traditional property access versus destructuring. Include cases where you rename variables during destructuring.