JS 里的数据类型转换

1, 转换成String字符串类型

  • toString()
    toString方法适用于number类型和boolean类型,如:

true.toString(); // "true"
(11).toString(); // "11"

但是对于null和undefined,使用这种方法会报错,如:

null.toString(); // Cannot read property 'toString' of null
undefined.toString(); // Cannot read property 'toString' of undefined

对于object.toSring方法结果不正确,结果是"[object Object]"

var obj = {}
obj.toString();//"[object Object]"

  • String() 该方法适用于所有数据类型(除了object,结果同toString())

String(obj); // "[object Object]"
String(11); // "11"
String(true); // "true"
String(undefined); // "undefined"

  • '' 即使用+运算符加上空字符串(同样对object无效)

true+""; // "true"
undefined+""; // "undefined"
obj+""; // "[object Object]"
11+""; // "11

2,转换成Number数值类型

  • Number()

Number(324) // 324 // 数值转换后还是原来的值
Number('324') // 324 // 字符串如果可以被解析为数值,则转换为相应的数值
Number('324abc') // NaN // 字符串如果不可以被解析为数值,返回 NaN
Number('') // 0 // 空字符串转为0
Number(true) // 1 Number(false) // 0 // 布尔值true 转成 1,false 转成 0字符串转为0
Number(undefined) // NaN // undefined转成 NaN
Number(null) // 0 // null转成0

  • parseInt()
    parseInt方法用于将字符串转为整数。如:parseInt('123') // 123
    如果字符串头部有空格,空格会被自动去除。parseInt(' 11') // 11
    parseInt的参数不是字符串,则会先转为字符串再转换。
    字符串转为整数的时候,是一个个字符依次转换,如果遇到不能转为数字的字符,就不再进行下去,返回已经转好的部分。如果字符串的第一个字符不能转化为数字(后面跟着数字的正负号除外),返回NaN。

parseInt('12.34') // 12
parseInt('15e2') // 15
parseInt('abc') // NaN
parseInt('.3') // NaN
parseInt('') // NaN
parseInt('+') // NaN
parseInt('+1') // 1

  • parseFloat()
    parseFloat方法用于将一个字符串转为浮点数。如果字符串符合科学计数法,则会进行相应的转换。
    如果字符串包含不能转为浮点数的字符,则不再进行往后转换,返回已经转好的部分。
    parseFloat方法会自动过滤字符串前导的空格。
    如果参数不是字符串,或者字符串的第一个字符不能转化为浮点数,则返回NaN。

parseFloat('3.14') // 3.14
parseFloat('3.14abc') // 3.14
parseFloat('0.0314E+2') // 3.14
parseFloat('') // NaN
parseFloat([]) // NaN

parseFloat的转换结果不同于Number函数,如:

parseFloat(true) // NaN
Number(true) // 1
parseFloat(null) // NaN
Number(null) // 0
parseFloat('') // NaN
Number('') // 0
parseFloat('123.45#') // 123.45
Number('123.45#') // NaN

  • 字符串 - 0,如:'22' - 0
    注:字符串不能有除了数字外的其他字符(正负号和表示进制的标识除外),字符串中,0b、0x、0o开头会以对应表示的进制解析,如果是'011',则会解析成十进制而不是二进制,小数同样可以用这两种方法进行转换。

'011'-0 // 11
'0b11'-0 // 3
'0o11'-0 // 9
'0x11'-0 // 17
'0x11.1'-0 // NaN
'011.1'-0 // 11.1

  • 字符串,这里的+并不是取正值的意思,负数一样可行,如:+ '11'; // 11 , + '-11' ; // -11

3,转换为Boolean布尔类型

  • Boolean()

Boolean("ss"); // true
Boolean({}); // true

  • 双重取反:!! x

!!"ss" ; // true
!!NaN ; // false
!!{} ; // true

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

推荐阅读更多精彩内容