Home Web Front-end JS Tutorial Access to Properties-deep dive

Access to Properties-deep dive

Oct 26, 2024 pm 05:46 PM

Access to Properties-deep dive

JavaScript is a versatile and powerful programming language used extensively in web development. One of its key features is the ability to define objects, which can encapsulate properties and methods. Among the various ways to interact with these objects, accessors play a crucial role.

Let's dive deeper into accessing properties in JavaScript.

Carrot Cake Recipe with JavaScript Objects

Let's create a JavaScript object representing a Carrot Cake recipe. We will use both dot notation and bracket notation to access its properties.

Step 1: Define the Carrot Cake Object

We'll define an object that includes properties such as ingredients, baking time, and instructions.

const carrotCake = {
    name: 'Carrot Cake',
    ingredients: {
        flour: '2 cups',
        sugar: '1 cup',
        carrots: '2 cups grated',
        eggs: '3 large',
        oil: '1 cup',
        bakingPowder: '2 tsp',
        cinnamon: '1 tsp',
        salt: '1/2 tsp'
    },
    bakingTime: '45 minutes',
    instructions: [
        'Preheat the oven to 350°F (175°C).',
        'In a bowl, mix flour, sugar, baking powder, cinnamon, and salt.',
        'In another bowl, whisk eggs and oil together.',
        'Combine the wet and dry ingredients, then fold in grated carrots.',
        'Pour the batter into a greased cake pan.',
        'Bake for 45 minutes or until a toothpick comes out clean.',
        'Let cool before serving.'
    ]
};

Copy after login
Copy after login

Step 2: Accessing Properties Using Dot Notation

You can access the properties of the carrotCake object using dot notation:

console.log(carrotCake.name); // Outputs: Carrot Cake
console.log(carrotCake.bakingTime); // Outputs: 45 minutes
console.log(carrotCake.ingredients.flour); // Outputs: 2 cups

Copy after login
Copy after login

Step 3: Accessing Properties Using Bracket Notation

You can also use bracket notation, especially useful for properties with spaces or when using dynamic keys:

console.log(carrotCake['name']); // Outputs: Carrot Cake
console.log(carrotCake['bakingTime']); // Outputs: 45 minutes
console.log(carrotCake['ingredients']['sugar']); // Outputs: 1 cup
Copy after login
Copy after login

Step 4: Looping Through Ingredients

You can loop through the ingredients using a for...in loop to display all ingredients:

for (const ingredient in carrotCake.ingredients) {
    console.log(`${ingredient}: ${carrotCake.ingredients[ingredient]}`);
}

Copy after login
Copy after login

This will output:

flour: 2 cups
sugar: 1 cup
carrots: 2 cups grated
eggs: 3 large
oil: 1 cup
bakingPowder: 2 tsp
cinnamon: 1 tsp
salt: 1/2 tsp

Copy after login

What Are JavaScript Object Accessors?

Accessors are methods that get or set the value of an object's property. They come in two forms: getters and setters.

Getters: Methods that get the value of a property.

Setters: Methods that set the value of a property.

These accessors provide a way to control how properties are accessed and modified. This can be useful for data validation, encapsulation, and providing computed properties.

Defining Getters and Setters

In JavaScript, you can define getters and setters within an object literal or using the Object.defineProperty method.

Using Object Literals

Here’s an example of how to define getters and setters in an object literal:

let person = {
    firstName: "Irena",
    lastName: "Doe",
    get fullName() {
        return `${this.firstName} ${this.lastName}`; // Returns full name
    },
    set fullName(name) {
        let parts = name.split(' '); // Splits the name into parts
        this.firstName = parts[0]; // Sets first name
        this.lastName = parts[1]; // Sets last name
    }
};

console.log(person.fullName); // Outputs: Irena Doe
person.fullName = "Jane Smith"; // Updates first and last name
console.log(person.firstName); // Outputs: Jane
console.log(person.lastName); // Outputs: Smith
Copy after login

Object Definition: You defined an object named person with properties firstName and lastName.

  • Getter: The fullName getter concatenates firstName and lastName to return the full name when accessed.
  • Setter: The fullName setter splits a provided full name string into parts and assigns the first part to firstName and the second part to lastName. Usage: When you log person.fullName, it correctly outputs "Irena Doe". After setting person.fullName to "Jane Smith", the firstName and lastName properties are updated accordingly.

To illustrate the difference between getters/setters and dot/bracket notation, let's enhance a Carrot Cake example. We will create an object with both direct property access and property access through getters and setters.
Step 1: Define the Carrot Cake Object
We'll define a carrotCake object that uses both direct properties and getters/setters for specific properties.

const carrotCake = {
    name: 'Carrot Cake',
    ingredients: {
        flour: '2 cups',
        sugar: '1 cup',
        carrots: '2 cups grated',
        eggs: '3 large',
        oil: '1 cup',
        bakingPowder: '2 tsp',
        cinnamon: '1 tsp',
        salt: '1/2 tsp'
    },
    bakingTime: '45 minutes',
    instructions: [
        'Preheat the oven to 350°F (175°C).',
        'In a bowl, mix flour, sugar, baking powder, cinnamon, and salt.',
        'In another bowl, whisk eggs and oil together.',
        'Combine the wet and dry ingredients, then fold in grated carrots.',
        'Pour the batter into a greased cake pan.',
        'Bake for 45 minutes or until a toothpick comes out clean.',
        'Let cool before serving.'
    ]
};

Copy after login
Copy after login
  • Step 2: Accessing Properties Using Dot and Bracket Notation Let's use dot notation to access and modify properties directly:
console.log(carrotCake.name); // Outputs: Carrot Cake
console.log(carrotCake.bakingTime); // Outputs: 45 minutes
console.log(carrotCake.ingredients.flour); // Outputs: 2 cups

Copy after login
Copy after login
  • Step 3: Accessing Properties Using Getters and Setters Now, let's access and modify properties using getters and setters:
console.log(carrotCake['name']); // Outputs: Carrot Cake
console.log(carrotCake['bakingTime']); // Outputs: 45 minutes
console.log(carrotCake['ingredients']['sugar']); // Outputs: 1 cup
Copy after login
Copy after login
  • Step 4: Updating Ingredients Using a method to update ingredients:
for (const ingredient in carrotCake.ingredients) {
    console.log(`${ingredient}: ${carrotCake.ingredients[ingredient]}`);
}

Copy after login
Copy after login

Let's recap the Differences

Dot/Bracket Notation:

  • Directly accesses or modifies properties.
  • No validation or logic is applied. E.g., carrotCake._name = '';would overwrite the name without checks. ###Getters/Setters:
  • Provides a controlled way to access and modify properties.
  • Can include custom logic, like validation in the setter. E.g., carrotCake.name = ''; prevents setting an empty name.

This example illustrates how you can use both approaches in a JavaScript object and highlights the benefits of getters and setters for encapsulating logic and ensuring data integrity.

Benefits of Using Accessors

  • Encapsulation
    Accessors allow you to hide the internal representation of an object while exposing a cleaner interface. This is a fundamental principle of encapsulation in object-oriented programming.

  • Validation
    Setters can be used to validate data before updating a property. This ensures that the object remains in a valid state.

Summary

In this example, we've created a simple JavaScript object to represent a carrot cake recipe. We accessed its properties using both dot and bracket notation, demonstrating how versatile property accessors can be in JavaScript.

JavaScript object accessors are a powerful feature that enhances the way you interact with object properties. By using getters and setters, you can add encapsulation, validation, computed properties, and read-only properties to your objects. Understanding and utilizing these accessors can lead to more robust, maintainable, and cleaner code. As you continue to explore and master JavaScript, incorporating accessors into your objects will undoubtedly be a valuable tool in your programming toolkit.

The above is the detailed content of Access to Properties-deep dive. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What should I do if I encounter garbled code printing for front-end thermal paper receipts? What should I do if I encounter garbled code printing for front-end thermal paper receipts? Apr 04, 2025 pm 02:42 PM

Frequently Asked Questions and Solutions for Front-end Thermal Paper Ticket Printing In Front-end Development, Ticket Printing is a common requirement. However, many developers are implementing...

Demystifying JavaScript: What It Does and Why It Matters Demystifying JavaScript: What It Does and Why It Matters Apr 09, 2025 am 12:07 AM

JavaScript is the cornerstone of modern web development, and its main functions include event-driven programming, dynamic content generation and asynchronous programming. 1) Event-driven programming allows web pages to change dynamically according to user operations. 2) Dynamic content generation allows page content to be adjusted according to conditions. 3) Asynchronous programming ensures that the user interface is not blocked. JavaScript is widely used in web interaction, single-page application and server-side development, greatly improving the flexibility of user experience and cross-platform development.

Who gets paid more Python or JavaScript? Who gets paid more Python or JavaScript? Apr 04, 2025 am 12:09 AM

There is no absolute salary for Python and JavaScript developers, depending on skills and industry needs. 1. Python may be paid more in data science and machine learning. 2. JavaScript has great demand in front-end and full-stack development, and its salary is also considerable. 3. Influencing factors include experience, geographical location, company size and specific skills.

How to merge array elements with the same ID into one object using JavaScript? How to merge array elements with the same ID into one object using JavaScript? Apr 04, 2025 pm 05:09 PM

How to merge array elements with the same ID into one object in JavaScript? When processing data, we often encounter the need to have the same ID...

Is JavaScript hard to learn? Is JavaScript hard to learn? Apr 03, 2025 am 12:20 AM

Learning JavaScript is not difficult, but it is challenging. 1) Understand basic concepts such as variables, data types, functions, etc. 2) Master asynchronous programming and implement it through event loops. 3) Use DOM operations and Promise to handle asynchronous requests. 4) Avoid common mistakes and use debugging techniques. 5) Optimize performance and follow best practices.

How to achieve parallax scrolling and element animation effects, like Shiseido's official website?
or:
How can we achieve the animation effect accompanied by page scrolling like Shiseido's official website? How to achieve parallax scrolling and element animation effects, like Shiseido's official website? or: How can we achieve the animation effect accompanied by page scrolling like Shiseido's official website? Apr 04, 2025 pm 05:36 PM

Discussion on the realization of parallax scrolling and element animation effects in this article will explore how to achieve similar to Shiseido official website (https://www.shiseido.co.jp/sb/wonderland/)...

The Evolution of JavaScript: Current Trends and Future Prospects The Evolution of JavaScript: Current Trends and Future Prospects Apr 10, 2025 am 09:33 AM

The latest trends in JavaScript include the rise of TypeScript, the popularity of modern frameworks and libraries, and the application of WebAssembly. Future prospects cover more powerful type systems, the development of server-side JavaScript, the expansion of artificial intelligence and machine learning, and the potential of IoT and edge computing.

The difference in console.log output result: Why are the two calls different? The difference in console.log output result: Why are the two calls different? Apr 04, 2025 pm 05:12 PM

In-depth discussion of the root causes of the difference in console.log output. This article will analyze the differences in the output results of console.log function in a piece of code and explain the reasons behind it. �...

See all articles