Maison > Article > interface Web > Pièges dans le problème de conversion implicite du test-JS écrit frontal
Lorsque nous rédigeons des questions de test écrit, nous rencontrons souvent des questions impliquant des conversions implicites, telles que
"1" + 2 obj + 1 [] == ![] [null] == false
===
sont appelés opérateurs stricts, les objets Le type pointe vers la même adresse ou la même valeur de type d'origine (valeur numérique, chaîne, valeur booléenne) ; ==
est appelé l'opérateur d'égalité. Si non défini et nul sont égaux, le type d'objet sera toujours. être comparés et référencés. L'opérateur ==
traite la valeur d'origine et son objet enveloppé comme égaux, mais l'opérateur ===
les traite comme inégaux.
All obj.a==null (équivalent à obj.a=== null || obj.a ===undefined
).
L'opérateur d'égalité est un piège qui provoque souvent une conversion implicite en JS. Il apparaît également souvent dans nos questions d'entretien. Cependant, dans le développement réel, afin d'éviter des problèmes inutiles, nous exigeons l'utilisation d'opérateurs stricts. Mais encore faut-il comprendre.
Si vous souhaitez comprendre la conversion implicite JS, vous devez d'abord commencer avec trois points de connaissances.
Les types primitifs (types de base, types de données primitifs, types de données primitifs) sont des données qui ne sont ni des objets ni des méthodes. En JavaScript, il existe 7 types : string,number,bigint,boolean,null,undefined,symbol (ECMAScript 2016新增)
.
valeur fausse (valeur virtuelle) est une valeur reconnue comme fausse dans un contexte booléen. Il n'y a que sept valeurs fausses dans. JavaScript.
En particulier, sauf ceci Tous sept objets ont de vraies valeurs, telles que new Number et new Boolean.
let b = new Boolean(false);i f(b){ //会执行到这里。 }
règle toString : Opérations de conversion d'autres types de valeurs en types de chaîne
Règle ToPrimitive : l'opération de conversion d'un tableau de type objet en un type primitif
Uncaught TypeError: Cannot convert object to primitive value
Règle ToNumber
Règles ToBoolean
Avec la compréhension des points de connaissance ci-dessus, nous pouvons supprimer la conversion implicite JS d'un seul coup fonce.
== 的过程
(优先换成数字、字符串)+的过程
(优先换成字符串、数字)-的过程
(转换成数字)
这个就很简单了,全部用ToNumber规则转换成数字我们根据以上所学看几个笔试题。如果你都知道结果,就不用看我的废解释了。
[] == [] [] == ![] [null] == false
第一个,==
左右都是对象,比较引用地址,这个两个不同的实例,肯定不相等啊。
第二个,!的优先级高于==
,所以先 [] 是真值,求非当让是false了,转成数字0,==
左是对象右是数字,对象使用ToPrimitive规则转换成""
,再用ToNumber规则就转成0了,判断为相等。
第三个,[null]ToPrimitive再ToNumber规则就转成0,false也转成0。
var a = 1; var b = "3"; var obj1 = { i:1, toString:function() { return "1"; }, valueOf:function() { return 1; } }; var obj2 = { i:1, toString:function() { return "2"; } }; var obj3 = { i:1, valueOf:function() { return 3; } }; var obj = { i:1, }; var objE = { i:1, valueOf:function() { return []; }, toString:function() { return {}; } }; a+b a + obj a + objE a+obj1 a+obj2 a+obj3 b+obj1 b+obj2 b+obj3 a==obj2 a==obj1
这道题比较简单你只要熟练掌握我上面说的那几个知识点可以了。下面直接写出结果啦。
a + b //"13" a + obj //"1[object Object]" a + objE //Uncaught TypeError: Cannot convert object to primitive value a+obj1 //2 a+obj2 //"12" a+obj3 // 4 b+obj1 //"31" b+obj2 //"32" b+obj3 //“33” a==obj2 //false a==obj1 //true
最后提一个比较奇葩的题目。
定义一个变量a,使得下面的表达式结果为true
a == 1 && a == 2 && a == 3
这里我简单提示下,a要是一个对象,重写valueOf方法,让它每次隐式转换的时候,调用时i++。
valueOf()在Object上默认返回的是对象不是原始类型,它会再调用toString。所以只要重写toString也可以。
如果还是没有思路,你们可以去看下这道题的文章原文从一道面试题说起—js隐式转换踩坑合集。
推荐教程:《JS教程》
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!