javaScript对象-基本包装类型的详解

本人按书上的内容大致地把javaScript对象划分成“引用类型”、“基本包装类型”和“内置对象”三块内容。

我们这篇先了解下基本包装类型的详细用法吧!

一、我们先解下相关概念:

1、引用类型的值(对象)是一个引用类型的一个实例。

  在ECMAScript中,引用类型是一种数据结构,用于将数据和功能组织在一起。它也通常称为类。

  尽管ECMASript中,从技术上讲是一门面向对象的语言,但它不具备传统的面向对象语言所支持的类和接口等基本结构。引用类型有时候也被称为对象定义,因为它们描述是一类对象所具有的属性和方法。

  为了便于操作基本数据类型,ECMAScript还提供了3个特殊的引用数据类型:Boolean、Number和String。

  在实际中我们每读取一个基本数据值的时候,后台就会创建一个对应的基本包装类型对象,从而让我们能够调用一些方法操作这些数据。

  如以下示例:

  var s1 = "some text";

  var s2 = s1.substring(2);

  猜猜后台会做什么样的事情,走,我们一起来看看:

  1、String类型的一个实例;

  2、在实例中调用指定的方法;

  3、销毁这个实例。

  可以将以上三个步骤想像成是执行以下ECMAStript代码。

  var s1 = new String("some text");

  var s2 = s1.substring(2);

  s1 = null;

  引用类型与基本包装类型的区别:

  它们的对象生命周期不同:

    • 引用类型:使用new创建引用类型的实例,在执行数据流离开当前作用域时会一直存储在内存中。
    • 基本包装类型:自动创建基本包装类型的对象,只执行一行代码的瞬间之后就会立即销毁。

    这意味着在运行时为基本包装类型值添加属性和方法是无效的。

二、走起,一起学习下基本包装类型的详细用法。

1、boolean  布尔对象类型

boolean对象用于转换一个不是Boolean类型的值转换为Boolean类型值(true或者false)。

  1.1  创建Boolean对象

      boolean对象代表两个值:“true”或者"false"

      下面的代码定义了一个名为myBoolean的布尔对象

      var myBoolean = new Boolean ();

      如果布尔对象无初始值或者其值为:

      • 0
      • -0
      • null
      • ""
      • false
      • undefined
      • NaN

       那么对象的值为false.否则,其值为true(即使当自变量为字符串"false"时)!

  1.2  boolean对象属性

      1.2.1  constructor属性

           语法:

           boolean.constructor

           定义和用法:

           constructor属性返回创建布尔对象的函数原型(即返回创建此对象的boolean函数的引用)。

           相关示例:

           返回通过myvar对象的原型创建的函数:

           var myvar = new boolean(1);

           myvar.constructor;

           结果输出:

           function Boolean (){ [native code]}

      1.2.2  boolean prototype构造器

           语法:

           Boolean.prototype.name=value;

           定义和用法:

           prototypen属性使您有能力向对象添加属性和方法。

           当构造一个原型,所有的布尔对象默认都添加属性或方法。

            注意:Boolean.prototype不是引用布尔值,但Boolean()对象是。

           注意: Prototype是一个全局属性,这对于几乎全部的javaScript对象。

           相关示例:

           Boolean.prototype.myColor=function ()

           {

             if (this.valueof()==true)

              {

                this.color="green";

              } else

              {

                this.color="red";

              }

           } 

           创建一个Boolean对象,并添加myColor方法:

           var a = new Boolean(1);

           a.,yColor();

           var b=a.color;

           结果输出:

           green

   1.3  boolean对象方法

        1.3.1 toString()方法

          语法:

          boolean.toString()

          定义和用法:

          toString() 方法可把一个逻辑值转换为字符串,并返回结果(true或false)。

          注意:当需要把boolean对象转换成字符串的情况,javaScript会自动调用此方法。

       1.3.2 valueOf()方法

          语法:

          boolean.valueOf()

          定义和用法:

          valueOf()方法可返回Boolean对象的原始值(true 或 false)。

          相关示例:

          返回Boolean 对象的原始值:

          var bool = new Boolean (0).

          var myvar = bool.valueOf();

          myvar输出结果:

          false

2、number  数字对象类型

      Number对象是原始数值的包装对象。

      Number创建方式 new Number().

      语法:

      var num = new Number(value);

   2.1  number对象属性

     2.1.1   constructor属性

             语法:

             number.constructor;

             定义和用法:

             constructor属性返回创建此对象的boolean函数的引用.

             相关示例:

             返回对创建此对象的number函数的引用:

             num.constructor;

             输出结果:

             function Number () {[native code]}

     2.1.2   MAX_VALUE属性

            语法:

             Number.MAX_VALUE;

            定义和用法

            MAX_VALUE属性是javaScript中可表示的最大的的数。

            它的近似值为1.7976931348623157 x 10308

           注意:大于MAX_VALUE的数表示无穷大。

           相关示例:

           示例1

           返回javaScript中的最大的数:

           Number.MAX_VALUE;

           返回值:

           1.7976931348623157e+308

           由于MAX_VALUE为Number对象的属性,所以可以使用Number.MAX_VALUE调用。

           使用自己创建的xNumber对象(x.MAX_VALUE)将无法获取。

           示例2

             MAX_VALUE是javaScript Number对象的静态属性,只能通过Number.MAX_VALUE调用。

            使用自定义的Numberx(x.MAX_VALUE)将无法获取MAX_VALUE属性;

            var x = 100;

            x.MAX_VALUE;

            x输出结果:

            undefined

3、string     字符串对象类型

posted @ 2016-08-03 00:09  心知梦圆  阅读(3896)  评论(0编辑  收藏  举报