Maison >interface Web >js tutoriel >Maîtriser les objets JavaScript : l'épine dorsale de la programmation dynamique

Maîtriser les objets JavaScript : l'épine dorsale de la programmation dynamique

Patricia Arquette
Patricia Arquetteoriginal
2024-12-20 17:24:10169parcourir

Mastering JavaScript Objects: The Backbone of Dynamic Programming

Objets JavaScript : un guide complet

Les objets JavaScript sont des éléments fondamentaux du langage, fournissant un moyen de regrouper les données et fonctionnalités associées. Ils sont essentiels au travail avec des données structurées et constituent le fondement de la programmation orientée objet en JavaScript.


1. Qu'est-ce qu'un objet en JavaScript ?

Un objet en JavaScript est une collection de propriétés, où chaque propriété a une clé (ou un nom) et une valeur. Les valeurs peuvent être de n'importe quel type de données, y compris d'autres objets ou fonctions.

Exemple:

const person = {
  name: "Alice",
  age: 30,
  greet: function () {
    console.log("Hello, " + this.name);
  }
};

2. Créer des objets

a. Littéraux d'objet

La manière la plus courante et la plus simple de créer des objets.

const car = {
  brand: "Tesla",
  model: "Model S",
  year: 2023
};

b. Utiliser new Object()

Crée un objet à l'aide du constructeur Object.

const book = new Object();
book.title = "JavaScript: The Good Parts";
book.author = "Douglas Crockford";

c. Utiliser une fonction constructeur

Constructeurs personnalisés pour créer des objets similaires.

function Person(name, age) {
  this.name = name;
  this.age = age;
}
const user = new Person("Bob", 25);

d. Utiliser les cours

Syntaxe moderne pour la création d'objets à l'aide de classes ES6.

class Animal {
  constructor(type, sound) {
    this.type = type;
    this.sound = sound;
  }
}
const dog = new Animal("Dog", "Bark");

3. Accéder aux propriétés de l'objet

Vous pouvez accéder aux propriétés en utilisant :

  • Notation par points :
  console.log(person.name);
  • Notation entre crochets : Utile pour les touches dynamiques ou les touches avec des caractères spéciaux.
  console.log(person["name"]);

4. Ajout, mise à jour et suppression de propriétés

  • Ajouter ou mettre à jour :
  person.hobby = "Reading"; // Adding a new property
  person.age = 31; // Updating an existing property
  • Supprimer :
  delete person.hobby;

5. Méthodes dans les objets

Une méthode est une fonction associée à un objet.

const person = {
  name: "Alice",
  age: 30,
  greet: function () {
    console.log("Hello, " + this.name);
  }
};

6. Vérification des propriétés

  • dans Opérateur :
const car = {
  brand: "Tesla",
  model: "Model S",
  year: 2023
};
  • Méthode hasOwnProperty :
const book = new Object();
book.title = "JavaScript: The Good Parts";
book.author = "Douglas Crockford";

7. Itérer à travers les propriétés de l'objet

  • for...in Loop : itère sur toutes les propriétés énumérables.
function Person(name, age) {
  this.name = name;
  this.age = age;
}
const user = new Person("Bob", 25);
  • Object.keys : renvoie un tableau de noms de propriétés.
class Animal {
  constructor(type, sound) {
    this.type = type;
    this.sound = sound;
  }
}
const dog = new Animal("Dog", "Bark");
  • Object.values : renvoie un tableau de valeurs de propriété.
  console.log(person.name);
  • Object.entries : renvoie un tableau de paires clé-valeur.
  console.log(person["name"]);

8. Objets imbriqués

Les objets peuvent contenir d'autres objets en tant que propriétés.

  person.hobby = "Reading"; // Adding a new property
  person.age = 31; // Updating an existing property

9. Déstructuration d'objets

Extraire les valeurs d'un objet vers des variables.

  delete person.hobby;

10. Opérateurs de propagation et de repos avec des objets

  • Opérateur de spread :
const calculator = {
  add: function (a, b) {
    return a + b;
  },
  subtract(a, b) {
    return a - b; // Shorthand syntax
  }
};
console.log(calculator.add(5, 3));
  • Opérateur de repos :
  console.log("name" in person); // true

11. Méthodes objets (statiques)

JavaScript fournit de nombreuses méthodes statiques pour les objets.

a. Objet.assign

Copie les propriétés d'un objet à un autre.

  console.log(person.hasOwnProperty("age")); // true

b. Objet.freeze

Empêche les modifications d'un objet.

  for (let key in person) {
    console.log(key, person[key]);
  }

c. Objet.seal

Autorise les mises à jour mais empêche l'ajout ou la suppression de propriétés.

  console.log(Object.keys(person));

d. Objet.create

Crée un nouvel objet avec un prototype spécifié.

  console.log(Object.values(person));

12. Références d'objets et clonage

Les objets sont stockés et manipulés par référence et non par valeur.

Clone peu profond :

  console.log(Object.entries(person));

Deep Clone (en utilisant JSON.parse et JSON.stringify) :

const company = {
  name: "Tech Corp",
  address: {
    city: "San Francisco",
    zip: "94105"
  }
};
console.log(company.address.city); // Access nested object

13. Prototypes et Héritage

Les objets en JavaScript ont un prototype, permettant l'héritage des propriétés et des méthodes.

const { name, age } = person;
console.log(name, age);

14. Cas d'utilisation courants des objets

  1. Stockage des paires clé-valeur : Les objets sont idéaux pour le stockage dynamique des propriétés.
  const newPerson = { ...person, gender: "Female" };
  1. Représenter des entités du monde réel :

    Les objets modélisent souvent des structures de données, comme les utilisateurs ou les produits.

  2. Fonctions de regroupement :

    Les objets peuvent servir de modules ou d'espaces de noms.

const person = {
  name: "Alice",
  age: 30,
  greet: function () {
    console.log("Hello, " + this.name);
  }
};

15. Considérations sur les performances

  • Réduisez l’imbrication profonde pour de meilleures performances.
  • Évitez la création fréquente d'objets dans du code critique en termes de performances.
  • Utilisez Map ou Set pour les données de paires clé-valeur volumineuses lorsque les performances sont cruciales.

Conclusion

Les objets JavaScript sont puissants et flexibles et constituent l'épine dorsale de la plupart des applications. Comprendre leurs fonctionnalités et capacités permet aux développeurs d'écrire du code efficace, maintenable et évolutif. La maîtrise des objets est une étape fondamentale pour maîtriser JavaScript.

Bonjour, je m'appelle Abhay Singh Kathayat !
Je suis un développeur full-stack avec une expertise dans les technologies front-end et back-end. Je travaille avec une variété de langages et de frameworks de programmation pour créer des applications efficaces, évolutives et conviviales.
N'hésitez pas à me contacter à mon e-mail professionnel : kaashshorts28@gmail.com.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn