JavaScript学习笔记——基本包装类型(上)Boolean、Number

为了便于操作基本类型值,ECMAScript还提供了三个特殊的引用类型:Boolean、Number和String。这些类型与其他引用类型相似,同时也具有与各自的基本包装类型相应的特殊行为。实际上,每当读取一个基本类型值时,后台就会创建一个对应的基本包装类型的对象,从而让我们能够调用一些方法来操作这些数据。

var s1 = "some text";
var s2 = s1.substring(2);

这个例子中的变量s1包含一个字符串,字符串当然是基本类型值。而下一行调用了s1的substring()方法,并将返回的结果保存在s2中。我们知道,基本类型值不是对象,因此从逻辑上讲,它们不应该有方法(但是它们确实有方法)。其实,为了让我们实现这种直观的操作,后台已经自动完成了一系列的处理。当第二行代码访问s1时,访问过程处于一种读取模式,也就是从内存中读取这个字符串的值。而在读取模式中访问字符串时,后台都会自动完成下列处理:
(1)创建String类型的一个实例。
(2)在实例上调用指定方法。
(3)销毁这个实例。

var s1 = new String("some text");
var s2 = s1.substring(2);
s1 = null;

引用类型与基本包装类型的主要区别就是对象的生命周期。使用new操作符创建的引用类型的实例,在执行流离开当前作用域之前都一直保存在内存中。而自动创建的基本包装类型的对象,只存在于这一行代码的执行期(瞬间),然后立即销毁。这就意味着我们不能在运行时为属性添加属性和方法。
Boolean类型
Boolean类型是与布尔值对应的引用类型。

var falseObject = new Boolean(false);
var result = falseObject && true;//true
var falseValue = false;
result = falseValue && true;//false

该引用类型的实例会修改valueOf()和toString()方法。前者返回基本类型值true 和false;后者返回字符串”true” 和”false”。所以falseValue返回基本类型true和fasle,false && true = false;falseObject 返回字符串”true” 和”false”,true && true = true。

alert(typeof falseObject );//object
alert(typeof falseValue);//Boolean
alert(falseObject instanceof Boolean);//true
alert(falseValue instanceof Boolean);//false

typeof操作符对基本类型返回“Boolean”,对引用类型返回“object”。由于Boolean对象是Boolean类型的实例,所以使用instanceof操作符测试Boolean对象会返回true,而测试基本类型的布尔值会返回false。
Number 类型
Number类型也重写了valueOf、toLocalString、toString方法,重写后的valueOf返回对象表示的基本类型的数值,其他两个方法则返回字符串形式的数值。

tostring()可以返回不同进制数值的字符串形式

var num = 10;
alert(num.toString());//"10"
alert(num.toString(2));//"1010"
alert(num.toString(8));//"12"
alert(num.toString(10));//"10"
alert(num.toString(16));//"a"

toFixed()方法会按照指定的小数位返回数值的字符串表示

var num1 = 10;
var num2 = 10.005;
alert(num1.toFixed(2));//"10.00"
alert(num2.toFixed(2));//"10.01"

toExponetial()返回一科学计数法表示的数值的字符串形式,也接受一个参数,才参数指定输出结果中的小数位数。

var num = 10;
alert(num.toExponetial(1));//"1.0e+1"

toPrecision()方法可以返回Fixed格式,也可以返回Exponetial格式。接受一个参数,表示数值的所有数字的位数(不包括指数部分)

var num = 99;
alert(num.toPrecision(1));//"1.0e+2"
alert(num.toPrecision(2));//"99"
alert(num.toPrecision(3));//"99.0"
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值