美文网首页js从0开始学习
js - 11 JS数据类型的转换

js - 11 JS数据类型的转换

作者: 大怪兽迪迦 | 来源:发表于2019-11-06 17:43 被阅读0次

类型转换

js中的取值类型很灵活,可以参考布尔类型,当期望使用一个布尔类型的值的时候可以提供任意类型的值,会根据需要来转换。(如:一些真值转换为true,一些假值转换为false; )

  • 这是常见的类型转换

上图总结:
1.以数字表示的字符串可以直接转换为数字,允许在开始和结尾处带空格(开头和结尾处的非空格不会被当成数字直接量的一部分,导致结果为NaN)
2.原始值通过调用String([val])、Number([val])、Boolean([val])构造函数转换为各自的包装对象
3.null和undefined属于例外,当你期望他们是对象时,会造成一个类型错误(TypeError)

转换和相等性

因为js较为灵活,所以 ‘==’ 相等运算符也随相等的含义灵活多变
如:

null == undefined;
"0" == 0;               // 在比较之前,“0”会转变为0
0 == false              // false会转变为0,再比较
“0” == false            // false转变为0,“0”转变为0

注意:一个值转换为另一个值时,并不会意味着这两个值相等,比如indefined会转换为false,false并不等于undefined.

显式类型转换

js中会自动的做某些转换,但有时却需要自己手动。
常见的方法有:

Number("3")                 // => 3
String(false)               // => "false"
Boolean([])                 // => true
Object(3)                   // => new Number(3)

另:某些运算符也会做隐示类型转换
’x + “”‘ 可以等价于String(x);
‘+ x’ 可以等价于Number(x),也可以写成 x - 0;
‘!!x’ 可以等价于Boolean(x),注意两个叹号;

js中提供了一些方法,可以使得Number to String/String to Number更简单

  • toString([val])
    可以接收表示转换基数的可选参数(就是指数)

    var a = 17;
    binary_string = a.toString(2);            // => "10001"(二进制)
    octal_string = a.toString(8);             // => "021"(八进制)
    hex_string = a.toString(16);              // => "0x11"(十六进制)
    
  • toFixed([val])
    根据小数点后的指定位数转换为字符串

    var a = 123456.789;
    a.toFixed(0);                 // => "1234567"
    a.toFixed(2):                 // => "123456.79"
    a.toFixed(5);                 // => "123456.78900"
    
  • toExponential([val])
    使用指数计数法来转换

    var a = 123456.789;
    a.toExponential(1);           // => "1.2e+5";
    a.toExponential(3);           // => "1.235e+5";
    
  • toPrecision([val])
    指定有效位莱转换

    var a = 123456.789;
    a.toPrecision(4);              // => "1.235e+5"
    a.toPrecision(7);              // => "1.23456.8"
    a.toPrecision(10);             // => "1.23456.7890"
    
  • 如果通过Number()转换函数传入一个字符串,他会试图将其转换为一个整数或者浮点数直接量

  • parseInt()
    全局函数,只解析整数

    parseInt("3 blind mice");         // => 3
    parseInt("3.14159");             // => 3
    parseInt("0xFF");                // => 255  
    parseInt("-0xFF");               // => -255
    parseInt(".1");                  // => NaN(整数不能以.开头)
    parseInt("11", 2)                // => 3(二进制)
    parseInt("zz", 36)               // => 1295(36进制)
    parseInt("077", 10)              // => 77(十进制)
    
  • parseFloat()
    全局函数,可以解析整数和浮点数

    parseFloat("3.14159");            // => 3.14159  
    parseFloat(".1");                // => 0.1 
    parseFloat("$72.14");            // => NaN(数字不能以'$'开头)
    

对象转换为值

对象到布尔值的转换很简单:所有对象都转换为true,包装对象也是这样:new Boolean(false) => true;
对象到字符串和数字是通过调用待转换对象的一个方法来完成的。
*以下方法只适用于本地对象,而宿主对象(如web浏览器定义的对象)根据各自的算法来转换

  • 所有对象都继承了两个方法:toString([val]),valueOf([val])

  • toString([val])
    作用是返回这个对象的字符串
    ({x:1, y:2}).string()               // => "[object Object]"
    [1,2,3].toString()                  // =>"1,2,3"
    (function(x){f(x);}).toString()     // =>"function(x){f(x);}"
    /\d+/g.toString()                  // => /\\d+/g
    new Date(2019,11,3).toString()      // =>"Wed Dec 04 2019 00:00:00 GMT+0800 (中国标准时间)"
    

  • valueOf([val])
    如果存在任意原始值,它就默认将对象转换为表示它的原始值;对象是复合值,而大多数对象无法真正表示为一个原始值,因此默认的valueOf()方法简单地返回对象本身,而不是返回一个原始值
    1.null和undefined
    null.valueOf()                        // => 报错
    undefined.valueOf()                   // => 报错
    
    2.布尔类型
    true.valueOf()                        // => true
    false.valueOf()                       // => false
    typeof Boolean.valueOf()              // => function
    typeof true.valueOf()                 // => Boolean
    
    3.字符串类型
    'asd'.valueOf()                       // => asd
    String.valueOf()                      // => String(){[native code]}
    
    4.数值类型
    123.valueOf()                         // => 报错
    (123).valueOf()                       // => 123
    
    5.对象类型
    {}.vlaueOf()                           // => 报错
    ({}).valueOf()                         // => Object {}
    typeof ({}).valueOf()                  // => 'object'
    ({a:123}).valueOf()                    // => Object{a:123}
    Object.valueOf()                       // => Object() { [native code] }
    typeof Object.valueOf()                // => 'function'
    function Person(){
        this.name = 'test';
    }
    var person1 = new Person();
    person1.valueOf()                     // => Person {name: "test"}
    
    6.函数
    function test(){                          functoin test(){
      alert("1")       test.vlaueOf():// =>       alert("1")
    }                                         }
    Function.valueOf()                   // => Function() { [native code] }
    
    7.数组
    [].vlaueOf()                          // => []
    
    8.时间
    var d = new Date(2019,11,4)           // => 2019年11月01日
    d.valueOf()                           // => 1575388800000
                                        (从1970,1,1以来的毫秒数)
    
  • 还有一些关于符号的转换
var now = new Date()                  // => 创建一个日期对象
typeof(now + 1)                       // => "string"("+"将日期转换为字符串)
typeof(now - 1)                       // => "number"("-"使用对象到数字的转换)
now == now.toString()                 // => true(隐式的和限式的字符串转换)
now > (now - 1)                       // => true(">"将日期转换为数字)

相关文章

  • 2、强制数据类型转换

    数据类型转换: 在js中,数据类型的转换有两种,分别是自动转换和强制转换 自动转换: 自动转换是用JS进行某些操作...

  • javaScript中数据类型转换方法

    JS 数据类型转换 方法主要有三种 转换函数、强制类型转换、利用js变量弱类型转换。 1. 转换函数: js提供了...

  • 数据类型转换

    JS 数据类型转换 方法主要有三种 转换函数、强制类型转换、利用js变量弱类型转换。 1. 转换函数: js提供了...

  • JavaScript基础总结

    ✍目录总览:(JS概念与组成、JS格式规范、JS基本语法【输入、输出、变量、数据类型、数据类型转换、运算符、流程控...

  • JS的基本小结

    JS基本输出方式 JS数据类型 变量 常量 变量常量小练习 声明提前 隐式转换 显示转换/强制转换

  • JavaScript的显式转换和隐式转换

    js的显式转换和隐式转换都是数据类型的转换;js的数据类型是弱类型的,即可以给变量赋值为任意的数据类型,当进行运算...

  • JavaScript 01 (JS引入/变量/数据类型/类型转换

    JS的引入及调试,常量,字面量,变量,JS中的数据类型,JS的运算符,JS的运算符之隐式类型转换,强制类型转换,M...

  • JS 里的数据类型转换

    JS 里的数据类型转换 Js中的数据类型一共有7种,即number,string,boolean,underfin...

  • js - 11 JS数据类型的转换

    类型转换 js中的取值类型很灵活,可以参考布尔类型,当期望使用一个布尔类型的值的时候可以提供任意类型的值,会根据需...

  • JS里的数据类型转换

    上一篇文章(JS里的数据类型)介绍了js中的数据类型。这篇主要介绍数据类型转换。 一、任意类型转字符串 转换成st...

网友评论

    本文标题:js - 11 JS数据类型的转换

    本文链接:https://www.haomeiwen.com/subject/oufpbctx.html