zoukankan      html  css  js  c++  java
  • 【JavaScript】Boolean

    以下内容为学习记录,可以参考 MDN 原文。

    环境

    • node v12.18.1
    • npm 6.14.5
    • vscode 1.46
    • Microsoft Edge 83

    概念

    Boolean 对象是一个布尔值的对象包装器。

    如果需要,作为第一个参数传递的值将转换为布尔值。如果省略或值 0,-0,null,false,NaN,undefined,或空字符串(""),该对象具有的初始值 false。所有其他值,包括任何对象,空数组([])或字符串 "false",都会创建一个初始值为的对象 true。

    注意不要将基本类型中的布尔值 true 和 false 与值为 true 和 false 的 Boolean 对象弄混了。

    其值不是 undefined 或 null 的任何对象(包括其值为false的布尔对象)在传递给条件语句时都将计算为 true。

    var x = new Boolean(false);
    if (x) {
      // 这里的代码会被执行
    }
    

    构造器

    Boolean() 创建一个新的 Boolean 对象。

    不要用创建 Boolean 对象的方式将一个非布尔值转化成布尔值,直接将 Boolean 当做转换函数来使用即可,或者使用双重非(!!)运算符:

    var x = Boolean(expression);     // 推荐
    var x = !!(expression);          // 推荐
    var x = new Boolean(expression); // 不太好
    

    对于任何对象,即使是值为 false 的 Boolean 对象,当将其传给 Boolean 函数时,生成的 Boolean 对象的值都是 true。

    var myFalse = new Boolean(false);   // true
    var g = new Boolean(myFalse);       // true
    var myString = new String("Hello");
    var s = new Boolean(myString);      // true
    

    最后,不要在应该使用基本类型布尔值的地方使用 Boolean 对象。

    实例方法

    toString

    toString() 方法返回指定的布尔对象的字符串形式。重写 Object.prototype.toString() 方法。

    const flag1 = new Boolean(true);
    
    console.log(flag1.toString());
    // expected output: "true"
    
    const flag2 = new Boolean(1);
    
    console.log(flag2.toString());
    // expected output: "true"
    

    name

    valueOf() 方法返回一个Boolean对象的原始值。重写 Object.prototype.valueOf() 方法。

    const x = new Boolean();
    
    console.log(x.valueOf());
    // expected output: false
    
    const y = new Boolean('Mozilla');
    
    console.log(y.valueOf());
    // expected output: true
    
  • 相关阅读:
    第二章 Java浮点数精确计算
    第一章 Java代码执行流程
    第九章 JVM调优推荐
    第八章 JVM性能监控与故障处理工具(2)
    基于Redis构建10万+终端级的高性能部标JT808协议的Gps网关服务器(转)
    基于Java Netty框架构建高性能的Jt808协议的GPS服务器(转)
    Netty(七):流数据的传输处理
    Java中的位运算符
    二进制(原码、反码、补码)
    Java数据结构和算法(二):数组
  • 原文地址:https://www.cnblogs.com/jiangbo44/p/13514777.html
Copyright © 2011-2022 走看看