How to set default boolean values in JavaScript?

后端 未结 5 1533
执念已碎
执念已碎 2021-01-31 01:38

Setting default optional values in JavaScript is usually done via the || character

var Car = function(color) {
  this.color = color || \'blue\';
};
         


        
相关标签:
5条回答
  • 2021-01-31 01:59

    Without much confusion you can do like this to get a default true.

    this.hasWheels=typeof hasWheels === 'boolean'?hasWheels:true

    To get a default false

    this.hasWheels=typeof hasWheels === 'boolean'?false

    0 讨论(0)
  • 2021-01-31 02:05

    You can use the Default function parameters feature in ECMA6. Today, ECMA6 is still not fully supported in the browser but you can use babel and start using the new features right away.

    So, the original example will become as simple as:

    // specify default value for the hasWheels parameter
    var Car = function(hasWheels = true) {
      this.hasWheels = hasWheels;
    }
    
    var myCar = new Car();
    console.log(myCar.hasWheels); // true
    
    var myOtherCar = new Car(false)
    console.log(myOtherCar.hasWheels); // false
    
    0 讨论(0)
  • 2021-01-31 02:07

    There are variations to be noted of from posted answers.

    var Var = function( value ) {
        this.value0 = value !== false;
        this.value1 = value !== false && value !== 'false';
        this.value2 = arguments.length <= 0 ? true : arguments[0];
        this.value3 = arguments[0] === undefined ? true : arguments[0];
        this.value4 = arguments.length <= 0 || arguments[0] === undefined ? true : arguments[0];
    };
    
                         value0   value1   value2        value3         value4
    ---------------------------------------------------------------------------
    Var("")              true     true     true          true           true
    Var("''")            true     true     ''            ''             ''
    Var("0")             true     true     0             0              0
    Var("'0'")           true     true     '0'           '0'            '0'
    Var("NaN")           true     true     NaN           NaN            NaN
    Var("'NaN'")         true     true     'NaN'         'NaN'          'NaN'
    Var("null")          true     true     null          null           null
    Var("'null'")        true     true     'null'        'null'         'null'
    Var("undefined")     true     true     undefined     true           true
    Var("'undefined'")   true     true     'undefined'   'undefined'    'undefined'
    Var("true")          true     true     true          true           true
    Var("'true'")        true     true     'true'        'true'         'true'
    Var("false")         false    false    false         false          false
    Var("'false'")       true     false    'false'       'false'        'false'
    
    • value1 is made especially from value0 for string 'false' if one needs it to be boolean false. I found this relaxation useful occationally.
    • value2 and value3 are modifications of original posted answers for consistency, without changed results.
    • value4 is how Babel compiles for default parameters.
    0 讨论(0)
  • 2021-01-31 02:12

    You can do this:

    this.hasWheels = hasWheels !== false;
    

    That gets you a true value except when hasWheels is explicitly false. (Other falsy values, including null and undefined, will result in true, which I think is what you want.)

    0 讨论(0)
  • 2021-01-31 02:12

    How about:

    this.hasWheels = (typeof hasWheels !== 'undefined') ? hasWheels : true;
    

    Your other option is:

    this.hasWheels = arguments.length > 0 ? hasWheels : true;
    
    0 讨论(0)
提交回复
热议问题