js中的== 与 === 的区别


在JavaScript中,`==`和`===`都是用于比较两个值的运算符,但它们的比较规则有所不同。 `==`(相等运算符) `==`在进行比较时会进行类型转换,即如果两个值的类型不同,它会尝试将它们转换为相同的类型,然后再进行比较。 ```javascript // 示例代码 console.log(5 == '5'); // true,这里字符串 '5' 会被转换为数字 5 再进行比较 console.log(true == 1); // true,布尔值 true 会被转换为数字 1 进行比较 console.log(null == undefined); // true,在使用 == 时,null 和 undefined 被视为相等 ``` `===`(严格相等运算符) `===`在进行比较时不会进行类型转换,只有当两个值的类型相同且值也相等时,才会返回`true`。 ```javascript // 示例代码 console.log(5 === '5'); // false,因为类型不同,一个是数字,一个是字符串 console.log(true === 1); // false,类型不同,一个是布尔值,一个是数字 console.log(null === undefined); // false,类型不同,一个是 null 类型,一个是 undefined 类型 ``` 我在以往的开发过程中,碰到过以下几点需要格外小心处理的地方: 1. 在使用`==`时,由于会进行类型转换,可能会导致一些意外的结果,因此尽量使用`===`来避免类型转换带来的问题。 2. 对于`NaN`的比较,无论是使用`==`还是`===`,`NaN`与任何值(包括它自身)比较都会返回`false`,如果需要判断一个值是否为`NaN`,可以使用`isNaN()`函数。 3. 在比较对象时,`==`和`===`比较的是对象的引用,而不是对象的内容,如果需要比较对象的内容,需要编写自定义的比较函数。 [2025-08-20 16:51:21 | AI写代码神器 | 439点数解答]
- cannot read properties of null (reading 'userid') typeerror: cannot read properties of null (reading 'userid') at eval (webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedruleset-40.use[0]!./node_modules/vue-loader/dist/index.js??ruleset[0].use[0]!./src/views/businesslistview.vue?vue&type=script&setup=true&lang=js:28:88) at eval (webpack-internal:///./node_modules/@vue/runtime-core/dist/runtime-core.esm-bundler.js:2677:40) at callwitherrorhandling (webpack-internal:/(614点数解答 | 2024-11-28 14:31:57)178
- <!doctype html> <html lang="zh"> <head> <meta charset="utf-8"> <link rel="stylesheet" href="css/mian.css"> <link rel="stylesheet" href="css/index.css"> <script src="js/jquery-3.3.1.min.js"></script> <script src="js/jquery-ui.min.js"></script> <script type="text/javascript"> // (1)创建js函数,使用jquery动画,实现ready事件 $(document). ____(1)____ (function(){ //ready事件 $('li').each(function(index){ //遍历对象 $(this).hover(function(){ //单击触发事件 $('li').animate({ width:100 },500); //删除当前元素的样式 $('li').eq(index).animate({ width:200 },500); }); }); }); </script> <title>首页</title> </head> <body> <header> <div class="logo"> <img src="img/logo.jpg" width="250" height="60"> </div> <form class="searchform"> <input type="text" name="search" id="search"/> <input type="submit" value="搜索" id="button"/> </form> <div class="navigation"> <a href="#">手机</a> | <a(475点数解答 | 2024-12-19 14:58:05)266
- <!doctype html> <html lang="zh"> <head> <meta charset="utf-8"> <link rel="stylesheet" href="css/mian.css"> <link rel="stylesheet" href="css/index.css"> <script src="js/jquery-3.3.1.min.js"></script> <script src="js/jquery-ui.min.js"></script> <script type="text/javascript"> // (1)创建js函数,使用jquery动画,实现ready事件 $(document). ____(1)____ (function(){ //ready事件 $('li').each(function(index){ //遍历对象 $(this).hover(function(){ //单击触发事件 $('li').animate({ width:100 },500); //删除当前元素的样式 $('li').eq(index).animate({ width:200 },500); }); }); }); </script> <title>首页</title> </head> <body> <header> <div class="logo"> <img src="img/logo.jpg" width="250" height="60"> </div> <form class="searchform"> <input type="text" name="search" id="search"/> <input type="submit" value="搜索" id="button"/> </form> <div class="navigation"> <a href="#">手机</a> | <a(495点数解答 | 2024-12-19 14:58:06)210
- <!doctype html> <html lang="zh"> <head> <meta charset="utf-8"> <link rel="stylesheet" href="css/mian.css"> <link rel="stylesheet" href="css/index.css"> <script src="js/jquery-3.3.1.min.js"></script> <script src="js/jquery-ui.min.js"></script> <script type="text/javascript"> // (1)创建js函数,使用jquery动画,实现ready事件 $(document). ____(1)____ (function(){ //ready事件 $('li').each(function(index){ //遍历对象 $(this).hover(function(){ //单击触发事件 $('li').animate({ width:100 },500); //删除当前元素的样式 $('li').eq(index).animate({ width:200 },500); }); }); }); </script> <title>首页</title> </head> <body> <header> <div class="logo"> <img src="img/logo.jpg" width="250" height="60"> </div> <form class="searchform"> <input type="text" name="search" id="search"/> <input type="submit" value="搜索" id="button"/> </form> <div class="navigation"> <a href="#">手机</a> | <a(497点数解答 | 2024-12-19 14:58:18)221
- <!doctype html> <html lang="zh"> <head> <meta charset="utf-8"> <link rel="stylesheet" href="css/mian.css"> <link rel="stylesheet" href="css/index.css"> <script src="js/jquery-3.3.1.min.js"></script> <script src="js/jquery-ui.min.js"></script> <script type="text/javascript"> // (1)创建js函数,使用jquery动画,实现ready事件 $(document). ____(1)____ (function(){ //ready事件 $('li').each(function(index){ //遍历对象 $(this).hover(function(){ //单击触发事件 $('li').animate({ width:100 },500); //删除当前元素的样式 $('li').eq(index).animate({ width:200 },500); }); }); }); </script> <title>首页</title> </head> <body> <header> <div class="logo"> <img src="img/logo.jpg" width="250" height="60"> </div> <form class="searchform"> <input type="text" name="search" id="search"/> <input type="submit" value="搜索" id="button"/> </form> <div class="navigation"> <a href="#">手机</a> | <a(497点数解答 | 2024-12-19 14:58:20)234
- <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Three.js 示例</title> <style> body { margin: 0; } canvas { display: block; } </style> </head> <body> <script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/r146/three.min.js"></script> <script> // 你的 Three.js 代码 const scene = new THREE.Scene(); const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000); const renderer = new THREE.WebGLRenderer(); (164点数解答 | 2025-02-27 23:30:20)155
- <!DOCTYPE html> <html> <head> <title>可360°观察的正交长方体</title> <style> body { margin: 0; overflow: hidden; } canvas { display: block; } </style> </head> <body> <script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/r128/three.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/three.js/r128/controls/OrbitControls.js"></script> <script> // 初始化场景 const scene = new THREE.Scene(); scene.background = new THREE.Color((466点数解答 | 2025-03-01 11:35:41)161
- cannot read properties of null (reading 'userid') typeerror: cannot read properties of null (reading 'userid') at eval (webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedruleset-40.use[0]!./node_modules/vue-loader/dist/index.js??ruleset[0].use[0]!./src/views/businesslistview.vue?vue&type=script&setup=true&lang=js:28:88)(523点数解答 | 2024-11-28 14:32:05)171
- cannot read properties of null (reading 'userid') typeerror: cannot read properties of null (reading 'userid') at eval (webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedruleset-40.use[0]!./node_modules/vue-loader/dist/index.js??ruleset[0].use[0]!./src/views/businesslistview.vue?vue&type=script&setup=true&lang=js:28:88) 要怎么修改代码(516点数解答 | 2024-11-28 14:32:43)190
- <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>湖南2025届高考物理公式手册</title> <script src="https://cdnjs.cloudflare.com/ajax/libs/jspdf/2.5.1/jspdf.umd.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/docx/7.4.1/docx.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.18.5/xlsx.full.min.js"></script> <script src="https://cdnjs.cloudflare.(405点数解答 | 2025-05-28 22:10:21)118
- <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>***新时代中国特色社会主义思想概论复习题库答案</title> <script src="https://unpkg.com/docx@7.1.0/build/index.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/FileSaver.js/2.0.5/FileSaver.min.js"></script> <style> * { box-sizing: border-box; margin: 0; padding: 0; font-family: "Mic(2009点数解答 | 2025-06-29 22:29:38)148
- 作为c++开发,new int[10]跟new int[10]()区别(196点数解答 | 2023-11-09 00:45:31)234