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
Libérer: 2024-12-20 17:24:10
original
154 Les gens l'ont consulté

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);
  }
};
Copier après la connexion
Copier après la connexion
Copier après la connexion

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
};
Copier après la connexion
Copier après la connexion

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";
Copier après la connexion
Copier après la connexion

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);
Copier après la connexion
Copier après la connexion

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");
Copier après la connexion
Copier après la connexion

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);
Copier après la connexion
Copier après la connexion
  • Notation entre crochets : Utile pour les touches dynamiques ou les touches avec des caractères spéciaux.
  console.log(person["name"]);
Copier après la connexion
Copier après la connexion

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
Copier après la connexion
Copier après la connexion
  • Supprimer :
  delete person.hobby;
Copier après la connexion
Copier après la connexion

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);
  }
};
Copier après la connexion
Copier après la connexion
Copier après la connexion

6. Vérification des propriétés

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

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);
Copier après la connexion
Copier après la connexion
  • 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");
Copier après la connexion
Copier après la connexion
  • Object.values : renvoie un tableau de valeurs de propriété.
  console.log(person.name);
Copier après la connexion
Copier après la connexion
  • Object.entries : renvoie un tableau de paires clé-valeur.
  console.log(person["name"]);
Copier après la connexion
Copier après la connexion

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
Copier après la connexion
Copier après la connexion

9. Déstructuration d'objets

Extraire les valeurs d'un objet vers des variables.

  delete person.hobby;
Copier après la connexion
Copier après la connexion

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));
Copier après la connexion
  • Opérateur de repos :
  console.log("name" in person); // true
Copier après la connexion

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
Copier après la connexion

b. Objet.freeze

Empêche les modifications d'un objet.

  for (let key in person) {
    console.log(key, person[key]);
  }
Copier après la connexion

c. Objet.seal

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

  console.log(Object.keys(person));
Copier après la connexion

d. Objet.create

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

  console.log(Object.values(person));
Copier après la connexion

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));
Copier après la connexion

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
Copier après la connexion

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);
Copier après la connexion

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" };
Copier après la connexion
  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);
  }
};
Copier après la connexion
Copier après la connexion
Copier après la connexion

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!

source:dev.to
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal