zoukankan      html  css  js  c++  java
  • js之数据类型的比较

    js中数据类型分基本数据类型和引用数据类型,然后它们又再细分,那么它们之间的比较又是怎么进行的呢?刚接触这个,真的是把我弄得特别懵,不过总结完以后,做了些练习好了很多,下面我来捋一捋。
    ==

    • 比较;返回一个布尔值;相等返回true,不相等返回false
    • 允许不同数据类型之间的比较;
    • 如果是不同类型的数据进行,会默认进行数据类型之间的转换;
        console.log(1 == 1);// true
        console.log(1 == "1");// true
        console.log(1 == "1px");//false
        console.log(1 == true);//true
        console.log([]==false)// true
        console.log([]==0)// true
        console.log(100 == false);// false
        console.log(188 == "188");// true
        console.log(false == " ");// true
    
    • 如果是对象数据类型的比较,比较的是空间地址
        console.log({}==[])// false
        console.log({}=={})// false
        console.log([]=="")// true
        console.log([]==0)// true
    

    既然有这么多数据类型,那么它们的比较肯定不是毫无章法的!

    • 数据类型比较规律
    1. 对象 ==布尔: 对象先转字符串再转数字,布尔转数字;
    2. 对象==对象: 比较是空间地址;
    3. 对象==数字 对象先转字符串,再转数字
    4. 对象==布尔: 对象先转字符串,再转数字,布尔转数字
    5. 对象==字符串 : 对象转字符串,字符串比较
    6. 布尔==字符串 : 布尔转数字,字符串转数字
    7. 布尔==数字: 布尔转数字
    8. 字符串==数字: 字符串转数字

    { } 对象toString 转换成字符串结果是"[object Object]"
    !(取反) : 会先把后面的值进行去布尔,然后再取反,最后比较
    0 " " NaN null undefined只有这五个值转布尔是false;

        console.log(![] == [])// true
        console.log([]==[])// false
        console.log(![]==false);//true
        console.log({a:1}=="[object Object]")// true
        console.log("12px" == 12);
    

    ===
    绝对比较; 只要数据类型不一样,那么返回false;
    console.log(1 === 1);// true
    console.log(1 === true);// false
    console.log(1 === "1");// false

  • 相关阅读:
    python pytesseract模块,报错
    CSS清除浮动_清除float浮动
    CSS中@import与link的具体区别
    js substr和substring的区别
    WebStorm 自定义字体+颜色+语法高亮+导入导出用户设置
    Jquery中的重置
    table标签中thead、tbody、tfoot的作用
    下拉列表框的几个属性
    使用GDI绘制文本
    使用GDI绘制一条直线
  • 原文地址:https://www.cnblogs.com/wangxingren/p/10110595.html
Copyright © 2011-2022 走看看