recherche
Maisoninterface Webjs tutorielMaîtriser les objets JavaScript : l'épine dorsale de la programmation dynamique

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
Applications JavaScript: de front-end à back-endApplications JavaScript: de front-end à back-endMay 04, 2025 am 12:12 AM

JavaScript peut être utilisé pour le développement frontal et back-end. L'endouage frontal améliore l'expérience utilisateur via les opérations DOM, et le back-end gère les tâches du serveur via Node.js. 1. Exemple frontal: modifiez le contenu du texte de la page Web. 2. Exemple backend: Créez un serveur Node.js.

Python vs JavaScript: Quelle langue devez-vous apprendre?Python vs JavaScript: Quelle langue devez-vous apprendre?May 03, 2025 am 12:10 AM

Le choix de Python ou JavaScript doit être basé sur le développement de carrière, la courbe d'apprentissage et l'écosystème: 1) le développement de carrière: Python convient à la science des données et au développement de back-end, tandis que JavaScript convient au développement frontal et complet. 2) Courbe d'apprentissage: la syntaxe Python est concise et adaptée aux débutants; La syntaxe JavaScript est flexible. 3) Ecosystème: Python possède de riches bibliothèques informatiques scientifiques, et JavaScript a un puissant cadre frontal.

Frameworks javascript: alimenter le développement Web moderneFrameworks javascript: alimenter le développement Web moderneMay 02, 2025 am 12:04 AM

La puissance du cadre JavaScript réside dans la simplification du développement, l'amélioration de l'expérience utilisateur et les performances des applications. Lorsque vous choisissez un cadre, considérez: 1. Taille et complexité du projet, 2. Expérience d'équipe, 3. Écosystème et soutien communautaire.

La relation entre JavaScript, C et BrowsersLa relation entre JavaScript, C et BrowsersMay 01, 2025 am 12:06 AM

INTRODUCTION Je sais que vous pouvez le trouver étrange, que doit faire exactement JavaScript, C et Browser? Ils semblent sans rapport, mais en fait, ils jouent un rôle très important dans le développement Web moderne. Aujourd'hui, nous discuterons du lien étroit entre ces trois. Grâce à cet article, vous apprendrez comment JavaScript fonctionne dans le navigateur, le rôle de C dans le moteur du navigateur et comment ils fonctionnent ensemble pour stimuler le rendu et l'interaction des pages Web. Nous connaissons tous la relation entre JavaScript et Browser. JavaScript est la langue principale du développement frontal. Il fonctionne directement dans le navigateur, rendant les pages Web vives et intéressantes. Vous êtes-vous déjà demandé pourquoi javascr

Node.js diffuse avec dactylographieNode.js diffuse avec dactylographieApr 30, 2025 am 08:22 AM

Node.js excelle dans des E / S efficaces, en grande partie grâce aux flux. Streams traite les données progressivement, en évitant la surcharge de mémoire - idéal pour les fichiers volumineux, les tâches réseau et les applications en temps réel. Combiner les flux avec la sécurité de type dactylographié crée un powe

Python vs JavaScript: considérations de performance et d'efficacitéPython vs JavaScript: considérations de performance et d'efficacitéApr 30, 2025 am 12:08 AM

Les différences de performance et d'efficacité entre Python et JavaScript se reflètent principalement dans: 1) comme un langage interprété, Python fonctionne lentement mais a une efficacité de développement élevée et convient au développement rapide des prototypes; 2) JavaScript est limité au thread unique dans le navigateur, mais les E / S multi-threading et asynchrones peuvent être utilisées pour améliorer les performances dans Node.js, et les deux ont des avantages dans les projets réels.

Les origines de JavaScript: explorer son langage d'implémentationLes origines de JavaScript: explorer son langage d'implémentationApr 29, 2025 am 12:51 AM

JavaScript est originaire de 1995 et a été créé par Brandon Ike, et a réalisé que la langue en langue C. 1.C offre des capacités de programmation élevées et au niveau du système pour JavaScript. 2. La gestion de la mémoire de JavaScript et l'optimisation des performances reposent sur le langage C. 3. La fonctionnalité multiplateforme du langage C aide JavaScript à s'exécuter efficacement sur différents systèmes d'exploitation.

Dans les coulisses: quel langage alimente JavaScript?Dans les coulisses: quel langage alimente JavaScript?Apr 28, 2025 am 12:01 AM

JavaScript s'exécute dans les navigateurs et les environnements Node.js et s'appuie sur le moteur JavaScript pour analyser et exécuter du code. 1) Générer une arborescence de syntaxe abstraite (AST) au stade d'analyse; 2) Convertir AST en bytecode ou code machine à l'étape de compilation; 3) Exécutez le code compilé à l'étape d'exécution.

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

Navigateur d'examen sécurisé

Navigateur d'examen sécurisé

Safe Exam Browser est un environnement de navigation sécurisé permettant de passer des examens en ligne en toute sécurité. Ce logiciel transforme n'importe quel ordinateur en poste de travail sécurisé. Il contrôle l'accès à n'importe quel utilitaire et empêche les étudiants d'utiliser des ressources non autorisées.

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux