JScript中值类型的封箱与拆箱

JScript中对象的expando属性是对Object,Array等引用类型增加成员的一种重要手段,但这种手段在对值类型时就不行了,比如
None.gif var  str  =   " string1 " ;
ExpandedBlockStart.gifContractedBlock.gifstr.method1 
=   function () dot.gif {
InBlock.gif
//do somethingdot.gif
ExpandedBlockEnd.gif
}
;
None.gif
None.gifstr.method1();
// 这里将出错,错误信息(我忘记了)是说str不存在该方法
None.gif

这样的语句就会运行不了,而在C#编程中值类型存在装箱与拆箱操作来将其转换为引用类型,对此,JScript中也存在值类型,我们也可以做个类似操作,其实现如下,其中 toJSON()的操作见 这里,其作用是将对象(泛指)用字符串表示出来,以便使用eval函数还原该对象。
ExpandedBlockStart.gif ContractedBlock.gif Boolean.prototype.box  =   function () dot.gif {
InBlock.gif    
return new Boolean( this );
ExpandedBlockEnd.gif}
;
ExpandedBlockStart.gifContractedBlock.gifNumber.prototype.box 
=   function () dot.gif {
InBlock.gif    
return new Number( this );
ExpandedBlockEnd.gif}
;
ExpandedBlockStart.gifContractedBlock.gifString.prototype.box 
=   function () dot.gif {
InBlock.gif    
return new String( this );
ExpandedBlockEnd.gif}
;
ExpandedBlockStart.gifContractedBlock.gifBoolean.prototype.unbox 
=   function () dot.gif {
InBlock.gif    
return eval( this.toJSON() );
ExpandedBlockEnd.gif}
;
ExpandedBlockStart.gifContractedBlock.gifNumber.prototype.unbox 
=   function () dot.gif {
InBlock.gif    
return eval( this.toJSON() );
ExpandedBlockEnd.gif}
;
ExpandedBlockStart.gifContractedBlock.gifString.prototype.unbox 
=   function () dot.gif {
InBlock.gif    
return eval( this.toJSON() );
ExpandedBlockEnd.gif}
;
box即为装箱,unbox即为拆箱。测试代码如下:
str  =   true .box();
alert( str );
str 
=  str.unbox();
alert( str );
虽然引用类型是不存在也不需要这两个过程的,但如果我们把形式统一的话,用起来就会更加方便,因此,我们再增加如下定义来配合:
None.gif
ExpandedBlockStart.gifContractedBlock.gif    Object.prototype.box 
=  Object.prototype.unbox  =   function () dot.gif {
InBlock.gif        
return this;
ExpandedBlockEnd.gif    }
;

至此,我们JScript也有了装箱操作,这有什么好处呢?再看看开头那段语句吧,此时我们就可以像对待Object一样对待String,Boolean,Number这三种值类型,就可以在运行时为值类型的变量增加expando属性,这样是不是很方便呢?
而拆箱操作也很简单,只需要调用类似str.unbox()就搞定。

转载于:https://www.cnblogs.com/Apq/archive/2006/04/04/366725.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值