Maison > interface Web > js tutoriel > Un bref résumé des points de connaissances sur le transfert de type de référence en Javascript

Un bref résumé des points de connaissances sur le transfert de type de référence en Javascript

黄舟
Libérer: 2017-03-22 14:56:47
original
1221 Les gens l'ont consulté

Cet article vous présente principalement les points de connaissance sur le type référence passant en Javascript L'article le présente de manière très détaillée. Les amis qui en ont besoin peuvent s'y référer. jetez un oeil ensemble.

Quels types dans JS sont des types de référence ?

Classe d'objet les types sont tous des types de référence.( fonction, tableau, date, expression rationnelle..)

Quels types de JS sont transmis par valeur ?

Les types de base sont tous transmis par valeur. par valeur signifie recopier Une copie est passée.

Comment passer une variable de type valeur comme type de référence ?

Vous pouvez utiliser un type de référence en enveloppant le type de base Pass.

ECMAScript fournit trois types de référence spéciaux (types d'emballage de base) : Boolean, String, Number.

La différence entre les types de référence et les types d'emballage de base : ObjectLa durée de vie est différente.

Voir code :

var str = "hello js"; 
var str2 = str.substring(2,5); 


// str2的形成 在JS内部是这样实现的.

var str = new String('hello js');
var str2 = str.substring(2,5);
str = null ;
Copier après la connexion

Allocation mémoire de type référence

Par exemple : var o = {name: ‘kobe'};

Pile : enregistre un pointeur, pointant vers l'adresse mémoire de l'objet sur le tas. Nous opérons les objets sur le tas via des poignées de pointeur.

Comprendre la différence entre == et ===

«===» Strict Opérateur

Règles de fonctionnement des opérateurs stricts :

1. Différents types de données

Si les types des deux valeurs sont différents, renvoient directement false.

2. Types de données de base (chaîne, booléen, nombre) du même type Si les valeurs sont les mêmes, renvoyez vrai si les valeurs sont différentes, renvoyez faux.

3. Types de données composites du même type

Lors de la comparaison de données de deux types composites (objets, tableaux, fonctions), ils ne comparent pas si leurs valeurs sont égales , mais comparez s'ils pointent vers le même objet.

4. indéfini et nul

console.log( [1] === [1] ) // false
Copier après la connexion

indéfini et nul sont strictement égaux à eux-mêmes.

"==" Opérateur d'égalité
console.log( null === null ) // true
console.log( undefined === undefined ) // true
Copier après la connexion

L'opérateur d'égalité est exactement le même que l'opérateur d'égalité stricte lors de la comparaison de données du même type.

Lors de la comparaison de données de différents types, l'opérateur d'égalité effectuera d'abord une

conversion de type

sur les données, puis les comparera avec l'opérateur d'égalité stricte. Les règles de conversion de type sont les suivantes (différents types sont discutés ci-dessous) :

1. Les valeurs sont toutes des types primitifs

Les données de type d'origine seront converties en <🎜. >type numérique
Comparez à nouveau.

2. Comparaison des objets et des valeurs de type primitif

Lorsqu'un objet (fait référence ici à un objet généralisé, comprenant des valeurs numériques et des fonctions) est comparé à une primitive valeur de type, l'objet est converti en valeur de type primitif, puis comparé.


3. non défini et nul

Lorsque undéfini et nul sont comparés à d'autres types de valeurs, le résultat est faux, et lorsqu'ils sont comparés entre eux, le résultat est vrai.


4. Inconvénients de l'opérateur d'égalité

console.log( null == undefined ) // true
Copier après la connexion
La conversion de type cachée de l'opérateur d'égalité apportera des résultats contre-intuitifs.


L'autre est le

jugement conditionnel

impliquant undéfini, le jugement conditionnel d'indéfini et nul.
console.log( "" == "0" ) // false 
console.log( 0 == "" ) // true
console.log( 0 == "0" ) // true
console.log( false == "false" ) // false
console.log( false == "0" ) // true
Copier après la connexion

Résumé

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal