js的特殊数据类型转换

Number()函数的转换规则如下

  1.   如果是 Boolean 值,true 和 false 将分别被转换为 1 和 0。  如果是数字值,只是简单的传入和返回。
  2.  如果是 null 值,返回 0。
  3.  如果是 undefined,返回 NaN。
  4.  如果是字符串,遵循下列规则:
  •   如果字符串中只包含数字(包括前面带正号或负号的情况),则将其转换为十进制数值,即"1" 会变成 1,"123"会变成 123,而"011"会变成 11(注意:前导的零被忽略了);

  •   如果字符串中包含有效的浮点格式,如"1.1",则将其转换为对应的浮点数值(同样,也会忽 略前导零);

  •   如果字符串中包含有效的十六进制格式,例如"0xf",则将其转换为相同大小的十进制整 数值;

  •   如果字符串是空的(不包含任何字符),则将其转换为 0;

  •   如果字符串中包含除上述格式之外的字符,则将其转换为 NaN。
     如果是对象,则调用对象的 valueOf()方法,然后依照前面的规则转换返回的值。如果转换

    的结果是 NaN,则调用对象的 toString()方法,然后再次依照前面的规则转换返回的字符

    串值。

  • var num1 = Number("Hello world!"); //NaN
    var num2 = Number(""); //0
    var num3 = Number("000011"); //11
    var num4 = Number(true); //1

    一元加操作符的操作与 Number()函数相同。 

    parseInt()函数

  • 在转换字符串时,更多的是看其是否符合数值模式。它会忽略字 符串前面的空格,直至找到第一个非空格字符。如果第一个字符不是数字字符或者负号,parseInt() 就会返回 NaN;也就是说,用 parseInt()转换空字符串会返回 NaN(Number()对空字符返回 0)。如 果第一个字符是数字字符,parseInt()会继续解析第二个字符,直到解析完所有后续字符或者遇到了 一个非数字字符。例如,"1234blue"会被转换为 1234,因为"blue"会被完全忽略。类似地,"22.5" 4 会被转换为 22,因为小数点并不是有效的数字字符。

  • var num1 = parseInt("1234blue"); // 1234
    var num2 = parseInt("");        // NaN
    var num3 = parseInt("0xA");    // 10(十六进制数) 
    var num4 = parseInt(22.5);     // 22
    var num5 = parseInt("070");    // 56(八进制数) 
    var num6 = parseInt("70");     // 70(十进制数) 
    var num7 = parseInt("0xf");    // 15(十六进制数)
    var num1 = parseInt("AF", 16); //175 
    var num2 = parseInt("AF");     //NaN
    var num1 = parseInt("10", 2);    //2 (按二进制解析)
    var num2 = parseInt("10", 8);    //8 (按八进制解析)
    var num3 = parseInt("10", 10);   //10(按十进制解析)
    var num4 = parseInt("10", 16);   //16(按十六进制解析) 
       
    

    parseFloat()函数

  • 从第一个字符(位置 0)开始解析每个字符。而且 也是一直解析到字符串末尾,或者解析到遇见一个无效的浮点数字字符为止。也就是说,字符串中的第 一个小数点是有效的,而第二个小数点就是无效的了,因此它后面的字符串将被忽略。举例来说, "22.34.5"将会被转换为 22.34。

    除了第一个小数点有效之外,parseFloat()与 parseInt()的第二个区别在于它始终都会忽略前导的零。parseFloat()可以识别前面讨论过的所有浮点数值格式,也包括十进制整数格式。但十六进制格 式的字符串则始终会被转换成 0。由于 parseFloat()只解析十进制值,因此它没有用第二个参数指定基 数的用法。最后还要注意一点:如果字符串包含的是一个可解析为整数的数(没有小数点,或者小数点后 都是零),parseFloat()会返回整数

  • var num1 = parseFloat("1234blue");    //1234 (整数)
    var num2 = parseFloat("0xA");         //0
    var num3 = parseFloat("22.5");        //22.5 
    var num4 = parseFloat("22.34.5");    //22.34 
    var num5 = parseFloat("0908.5");     //908.5    
    var num6 = parseFloat("3.125e7");    //31250000
    

    String(用双引号表示的字符串和用单引号表示的字符串完全相同一个值转换为一个字符串

  • 如果值有 toString()方法,则调用该方法(没有参数)并返回相应的结果;

  • 如果值是 null,则返回"null";

  • 如果值是 undefined,则返回"undefined"

  • var age = 11;
    var ageAsString = age.toString(); // 字符串"11" 
    var found = true;
    var foundAsString = found.toString(); // 字符串"true"
    
    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"
    
    var value1 = 10;
    var value2 = true;
    var value3 = null;
    var value4;
    alert(String(value1));    // "10"
    alert(String(value2));    // "true"
    alert(String(value3));    // "null"
    alert(String(value4));    // "undefined"
    

     因为 null 和 undefined 没有 toString()方法,所以 String() 函数就返回了这两个值的字面量 

  • object(Object 的每个实例都具有下列属性和方法

  • constructor:保存着用于创建当前对象的函数。对于前面的例子而言,构造函数(constructor) 8 就是 Object()。

  • hasOwnProperty(propertyName):用于检查给定的属性在当前对象实例中(而不是在实例 的原型中)是否存在。其中,作为参数的属性名(propertyName)必须以字符串形式指定(例 如:o.hasOwnProperty("name"))。

  • isPrototypeOf(object):用于检查传入的对象是否是传入对象的原型。

  • propertyIsEnumerable(propertyName):用于检查给定的属性是否能够使用 for-in 语句 (本章后面将会讨论)来枚举。与 hasOwnProperty()方法一样,作为参数的属性名必须以字符串形式指定。

  • toLocaleString():返回对象的字符串表示,该字符串与执行环境的地区对应。

  • toString():返回对象的字符串表示。

  • valueOf():返回对象的字符串、数值或布尔值表示。通常与 toString()方法的返回值相同。

  • var o = new Object();

猜你喜欢

转载自blog.csdn.net/banxia561/article/details/81332067