在 JavaScript 中是否有原始变量的用途

is there ever a use for primitive variables in javascript?

本文关键字:变量 原始 JavaScript 是否      更新时间:2023-09-26

一个非常简单的问题,在javascript中使用原始数据类型是否更可取,我特别受到原始布尔值的困扰,请考虑以下代码

var bool = new Boolean(false);
if (bool){
    alert(bool);
}

它会alert但你会得到false,这有点令人困惑(false!= falsy)。

那么使用原始数据类型,尤其是原始布尔值有什么意义吗?

这些不是基元。基元像100"foobar"false

> typeof false
"boolean"
> typeof new Boolean(false)
"object"

new Boolean(或NumberString)是一个对象,遵循对象的规则,而不是基元的规则进行比较,布尔转换等。这些对象对于JS程序员来说确实几乎没有用处(与内部使用它们的JS引擎相反)。

请注意,虽然很少需要使用Boolean和友元来构造对象(如x = new Boolean(...)),但这些函数有时本身很有用。例如,以下不错的习惯用法从数组中删除所有 faly 值:

ary = ary.filter(Boolean)

基元值非常有用(例如基元值:真、假、空、1、2 等)。您在问题中谈论的是它们周围的对象包装器。

对象包装器很有用,因为它允许您添加要对其调用的函数。更重要的一点是,当您对基元值调用方法时,会在它们上创建对象包装器,并在对象包装器*上调用方法。

示例 1:字符串

String.prototype.sayHello = function() {
  return this + ' says hello';
};
// calling a method on a string literal temporarily converts it to a String
console.log('John'.sayHello()); // 'John says hello'

示例 2:布尔值

var bool = new Boolean(false);
console.log(bool); // Boolean
console.log(bool.toString()); // 'false'
console.log(bool.valueOf()); // false
// How you can use it:
Boolean.prototype.toCaps = function() {
  return this.valueOf().toString().toUpperCase();
};
console.log(bool.toCaps()); // 'FALSE'
// calling a method on a boolean literal temporarily converts it to a Boolean
console.log(true.toCaps()); // 'TRUE'
console.log((1 === 1).toCaps()); // 'TRUE'

演示:http://jsbin.com/apeGOve/1/edit

*)每次对基元值调用方法时,都会创建不同的对象包装器:

String.prototype.getWrapper = function() { return this; };
String.prototype.setTest = function() { this.test = 'test' };
String.prototype.getTest = function() { return this.test; };
var str = '123';
console.log('Different wrappers each time',str.getWrapper() === str.getWrapper());
var wrapper = str.getWrapper();
wrapper.setTest();
console.log(wrapper.getTest());
console.log(str.getTest());

您的示例:

var bool = new Boolean(false);
if (bool){
    alert(bool);
}

你想知道为什么它会发出错误的警报。

bool变量,您在创建变量时为其分配了一个值。所以,当你说 JavaScript if(bool)做一些强制并测试bool是否是假的时,它不是,所以条件块会执行。现在,您将alert(bool)尝试调用对象的 toString 方法并显示结果。布尔对象的 toString 方法将布尔对象的值作为字符串返回,因此,您会收到单词"false"警报。

来吧,试试

var bool = new Boolean(false);
bool.toString = function () {
    return 'I need a banana';
}
if (bool){
    alert(bool);
}

你会得到完全不同的结果。

这就引出了你的另一个问题,即"为什么"你甚至会使用布尔构造函数:你可以为布尔对象分配属性,你不能为truefalse分配属性。例如,在使用可链接方法构建一些逻辑处理库时,您可能希望从布尔对象继承。