首页
Javascript
Html
Css
Node.js
Electron
移动开发
工具类
服务端
浏览器相关
前端收藏
其他

javscript原始数据类型相互转换

2013年01月22日 发布 阅读(256) 作者:懒炖

转换成字符串:

1、toString()方法:数值、布尔值、对象以及字符串本身都有toString()方法,但null和undefined没有这个方法。

默认情况下,toString()以十进制格式返回数值的字符串表示,可以传递一个参数,来返回以二进制,八进制,十六进制,甚至其他任何有效进制格式表示的字符串值

  1. alert('这是字符串'.toString());//返回"这是字符串"
  2. var number = 1299;
  3. alert(number.toString());//返回字符串"1299";
  4. //1299.toString(),这种写法错误
  5. //利用toString()转换进制
  6. alert(number.toString(16))//转换成2进制,返回513
  7. alert(number.toString(8))//转换成2进制,返回2423
  8. alert(number.toString(2))//转换成2进制,返回10100010011
  9. alert(true.toString());//返回字符串"true",false返回字符串"false"
  10. alert({"type":"object"}.toString());//不能转换成字符串
  11. alert([0,1].toString());//返回字符串"0,1"
  12. alert("".toString())//返回""空字符串
  13. alert(NaN.toString());//返回字符串 "NaN"
  14. //注意:null和undefined 没有toString方法
  15. alert(undefined.toString());//不返回值
  16. alert(null.toString())//不返回值

2、String()方法:强制转换成字符串。在不知道转换的值是不是null或undefined的时候,可能用String()方法,String()方法可以把任何类型的值转换成字符串

  1. alert(String(null)) //返回字符串"null"
  2. alert(String(undefined))//返回字符串"undefined"
  3. //其他数据类型跟toString()转换的一样

转换成数字:

1、用Number()方法:强制转换成数字,遵循下列规则

  1. //如果是Boolean值,true和false分别转换成1和0
  2. alert(Number(true));//返回1
  3. alert(Number(false));//返回0
  4. alert(Number(null));//返回0
  5. alert(Number(undefined));//返回NaN
  6. //如果是字符串,会忽略前导0,并以十进制格式返回
  7. alert(Number(""));//返回0
  8. alert(Number("011"));//返回11
  9. alert(Number("01.1"));//返回1.1
  10. alert(Number("0xf"));//括号中为有效的十六进制值,返回等值的十进制值 :15
  11. //如果是对象,则先调用valueOf(),再调用toString()
  12. alert(Number({}));//返回NaN
  13. alert(Number([1,2]));//返回NaN

2、parseInt()方法:一般用于处理字符串,转换成整数,它会忽略字符串前的空格。如果第一个字符不是数字字符或负号,parseInt()会返回NaN

  1. alert(parseInt("12306blue")); //返回12306
  2. alert(parseInt("-12306blue")); //返回-12306
  3. alert(parseInt("")); //返回NaN
  4. alert(parseInt("0xA")); //返回10(十六进制)
  5. alert(parseInt("22.2")); //返回22
  6. alert(parseInt("070")); //返回56(八进制)
  7. alert(parseInt("70")); //返回70 (十进制
  8. alert(parseInt(true));//返回NaN
  9. alert(parseInt(null));//返回NaN
  10. alert(parseInt(NaN)); //返回NaN
  11. alert(parseInt([3,2]));//返回3,先把数组转换成字符串,再返回数字
  12. alert(parseInt(["a",2])); //返回NaN,因为转换成字符串后,第一个字符不是数字字符
  13. alert(parseInt({"type":"object"}));//返回NaN
  14. alert(parseInt({0:"object"}));//返回NaN
  15. alert(parseInt(undefined));//返回NaN

parseInt()转换十六进制时,可能会判断错误,返回NaN,这时可以为parseInt()设置第二个参数,指定要转换的基数,如下:

  1. alert(parseInt("AF")); //返回NaN
  2. alert(parseInt("AF",16));//返回175

3、parseFloat():转换成浮点数 ,浮点类型没有基数模式(即没有第二个参数,只能转换十进制值)

使用parseFloat需要注意以下几点:

a.与parseInt()一样,也是从第一个字符开始解析,如果第一个字符不是数字或负号或点(.)号【parseInt()中,第一个字符为点号时返回NaN】,则返回NaN

b.parseFloat()会忽略前导所有的”0”

  1. alert(parseFloat(""));//返回NaN
  2. alert(parseFloat(NaN));//返回NaN
  3. alert(parseFloat("blue12345"));//返回NaN
  4. alert(parseFloat("20.34.12"))//返回20.34
  5. alert(parseFloat(".34.12"))//返回0.34,用parseInt(".34.12")返回NaN
  6. alert(parseFloat("-23"))//返回-23
  7. alert(parseFloat("000012"));//返回12;
  8. alert(parseFloat("0xA")); //返回0,不是返回十六进制值

转换成布尔类型:

可以使用Boolean()强制转换成布尔类型,遵循下面规则:

1、当值为非空字符串,非0数字,或是对象时,返回true

2、当值为数字0,null,NaN或空字符串时,返回false

数据类型 转换为true的值 转换为false的值
Boolean true false
String 任何非空字符串 “”空字符串
Number 任何非0数字值(包括无穷大) 0和NaN
Object 任何对象 null
Undefined —–不适用 undefined
简单测试了一些常的Boolean()返回值

  1. alert(Boolean("a"));//返回true
  2. alert(Boolean(2));//返回true
  3. alert(Boolean({}));//返回true
  4. alert(Boolean(0));//返回false
  5. alert(Boolean("0"));//返回true
  6. alert(Boolean(null))//返回false
  7. alert(Boolean(""))//返回false
  8. alert(Boolean(NaN));//返回false
  9. alert(Boolean("true"));//返回true
  10. alert(Boolean("false"));//返回true
  11. alert(Boolean(undefined));//返回false
  12. alert(Boolean("undefined"));//返回true方法:数值、布尔值、对象以及字符串本身都有toString()方法,但null和undefined没有这个方法。

默认情况下,toString()以十进制格式返回数值的字符串表示,可以传递一个参数,来返回以二进制,八进制,十六进制,甚至其他任何有效进制格式表示的字符串值

  1. alert('这是字符串'.toString());//返回"这是字符串"
  2. var number = 1299;
  3. alert(number.toString());//返回字符串"1299";
  4. //1299.toString(),这种写法错误
  5. //利用toString()转换进制
  6. alert(number.toString(16))//转换成2进制,返回513
  7. alert(number.toString(8))//转换成2进制,返回2423
  8. alert(number.toString(2))//转换成2进制,返回10100010011
  9. alert(true.toString());//返回字符串"true",false返回字符串"false"
  10. alert({"type":"object"}.toString());//不能转换成字符串
  11. alert([0,1].toString());//返回字符串"0,1"
  12. alert("".toString())//返回""空字符串
  13. alert(NaN.toString());//返回字符串 "NaN"
  14. //注意:null和undefined 没有toString方法
  15. alert(undefined.toString());//不返回值
  16. alert(null.toString())//不返回值

2、String()方法:强制转换成字符串。在不知道转换的值是不是null或undefined的时候,可能用String()方法,String()方法可以把任何类型的值转换成字符串

  1. alert(String(null)) //返回字符串"null"
  2. alert(String(undefined))//返回字符串"undefined"
  3. //其他数据类型跟toString()转换的一样

转换成数字:

1、用Number()方法:强制转换成数字,遵循下列规则

  1. //如果是Boolean值,true和false分别转换成1和0
  2. alert(Number(true));//返回1
  3. alert(Number(false));//返回0
  4. alert(Number(null));//返回0
  5. alert(Number(undefined));//返回NaN
  6. //如果是字符串,会忽略前导0,并以十进制格式返回
  7. alert(Number(""));//返回0
  8. alert(Number("011"));//返回11
  9. alert(Number("01.1"));//返回1.1
  10. alert(Number("0xf"));//括号中为有效的十六进制值,返回等值的十进制值 :15
  11. //如果是对象,则先调用valueOf(),再调用toString()
  12. alert(Number({}));//返回NaN
  13. alert(Number([1,2]));//返回NaN

2、parseInt()方法:一般用于处理字符串,转换成整数,它会忽略字符串前的空格。如果第一个字符不是数字字符或负号,parseInt()会返回NaN

  1. alert(parseInt("12306blue")); //返回12306
  2. alert(parseInt("-12306blue")); //返回-12306
  3. alert(parseInt("")); //返回NaN
  4. alert(parseInt("0xA")); //返回10(十六进制)
  5. alert(parseInt("22.2")); //返回22
  6. alert(parseInt("070")); //返回56(八进制)
  7. alert(parseInt("70")); //返回70 (十进制
  8. alert(parseInt(true));//返回NaN
  9. alert(parseInt(null));//返回NaN
  10. alert(parseInt(NaN)); //返回NaN
  11. alert(parseInt([3,2]));//返回3,先把数组转换成字符串,再返回数字
  12. alert(parseInt(["a",2])); //返回NaN,因为转换成字符串后,第一个字符不是数字字符
  13. alert(parseInt({"type":"object"}));//返回NaN
  14. alert(parseInt({0:"object"}));//返回NaN
  15. alert(parseInt(undefined));//返回NaN

parseInt()转换十六进制时,可能会判断错误,返回NaN,这时可以为parseInt()设置第二个参数,指定要转换的基数,如下:

  1. alert(parseInt("AF")); //返回NaN
  2. alert(parseInt("AF",16));//返回175

3、parseFloat():转换成浮点数 ,浮点类型没有基数模式(即没有第二个参数,只能转换十进制值)

使用parseFloat需要注意以下几点:

a.与parseInt()一样,也是从第一个字符开始解析,如果第一个字符不是数字或负号或点(.)号【parseInt()中,第一个字符为点号时返回NaN】,则返回NaN

b.parseFloat()会忽略前导所有的”0”

  1. alert(parseFloat(""));//返回NaN
  2. alert(parseFloat(NaN));//返回NaN
  3. alert(parseFloat("blue12345"));//返回NaN
  4. alert(parseFloat("20.34.12"))//返回20.34
  5. alert(parseFloat(".34.12"))//返回0.34,用parseInt(".34.12")返回NaN
  6. alert(parseFloat("-23"))//返回-23
  7. alert(parseFloat("000012"));//返回12;
  8. alert(parseFloat("0xA")); //返回0,不是返回十六进制值

转换成布尔类型:

可以使用Boolean()强制转换成布尔类型,遵循下面规则:

1、当值为非空字符串,非0数字,或是对象时,返回true

2、当值为数字0,null,NaN或空字符串时,返回false

数据类型 转换为true的值 转换为false的值
Boolean true false
String 任何非空字符串 “”空字符串
Number 任何非0数字值(包括无穷大) 0和NaN
Object 任何对象 null
Undefined —–不适用 undefined
简单测试了一些常的Boolean()返回值

  1. alert(Boolean("a"));//返回true
  2. alert(Boolean(2));//返回true
  3. alert(Boolean({}));//返回true
  4. alert(Boolean(0));//返回false
  5. alert(Boolean("0"));//返回true
  6. alert(Boolean(null))//返回false
  7. alert(Boolean(""))//返回false
  8. alert(Boolean(NaN));//返回false
  9. alert(Boolean("true"));//返回true
  10. alert(Boolean("false"));//返回true
  11. alert(Boolean(undefined));//返回false
  12. alert(Boolean("undefined"));//返回true
版权声明:本站文章除特别声明外,均采用署名-非商业性使用-禁止演绎 4.0 国际 许可协议,如需转载,请注明出处

评论

  •  
  • 批量转换LF和CRLF的小技巧

    做跨平台开发移植的时候,最常见的问题就是不同操作系统的换行不同(例如,Windows 上是 CRLF,而 Linux 上是 LF,MacOS 以前是 CR,现在也是 LF),如果不注意的话,可能会导致编译的时候报诡异的错误,虽然说有些优秀的文本工具(notepad++, vscode 等)可以自动转换,但是它们都没有提供批量转换的方法,所以一旦遇到有成百上千个的文件需要转换,那么一个个手动去转明显效率低下。虽然网上提到批量转换的文章很多,但是感觉都没有介绍清楚,可能大神们都觉得太简单了吧。。。为了同学们能够和我一样少走弯路,我就把我的转换过程详细记录下来。

    发布:2019-05-24 阅读(227)

  • nodejs应用转换png,jpg,gif为webp图片格式

    nodejs应用如果在服务端使用npm包转换jpg,png,gif为webp格式,大大缩小图片的大小

    发布:2019-03-01 阅读(510)

  • 为什么要在javascript中进行静态类型检查.Part2&3[译]

    在第一部分中我们了解了许多基础知识,结束了语法的学习,我们可以进入下一个更有趣的部分:使用静态类型的优势和劣势

    发布:2018-12-21 来源:AlienZHOU

  • 为什么要在javascript中进行静态类型检查.Part1[译]

    作为一个JavaScript开发者,你可以编写一整天编写也不会遇到任何静态类型检查得问题。那么为什么要自找麻烦得去学习它呢? 然而学习静态类型并不仅仅是一个思维拓展的训练。如果你愿意花点时间来学习一些静态类型的优势、劣势以及使用的案例,那将会极大的帮助你进行编码。 怎么样,有意思吧?要是你感兴趣的话,那接下来四个部分将会向你详细解释

    发布:2018-12-21 来源:AlienZHOU

  • javascript原始数据类型相互转换

    javascript原始数据类型相互转换示例,如字符串、数字、布尔类型的相互转换

    发布:2013-10-19 阅读(269)

  • 利用Object.prototype.toString判断javascript数据类型(数组,函数,类对象{},布尔类等)

    一般情况下,判断javasceript数据类型,使用typeof 或 instanceof 就够了,但偶觉得用起来还是别别扭扭的。这里介绍一个完美的方法,我们可以轻松的判断数组,对象(这里对象暂且指{}),函数(function),布尔(Boolean),null,undefined,number,时间对象(date),正则表达式(RegExp)。

    发布:2013-08-12 阅读(173)

  • Javascript数字类型小数表示方式的三种方法:toFixed,toExponential,toPrecision

    javascript提供了三个方法来计算表示小数点的位数:toFixed,toExponential,toPrecision

    发布:2013-05-30 阅读(219)

  • Javascript基本数据类型[Undefined,null,String,Number,Boolean]

    Javascript有五种基本的数据类型:Undefined,null,String,Number,Boolean,这五种数据类型都可以用typeof来检测

    发布:2013-01-05 阅读(188)

  • javascript检测IE6/7/8,chrome,safari,firefox,opera等主流浏览器类型

    利用javascript检测浏览器的类别,网上也会有很多的代码,这里总结写了一下,主要检测主流的五款浏览器(IE,Chrome,Opera,Safari,Firefox)的类别,IE可以检测到IE6-IE9的本种版本,IE10没有检测过。

    发布:2012-11-27 阅读(195)