js - 11 JS数据类型的转换

类型转换

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(">"将日期转换为数字)
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容