JS数字和字符串的相互转换

数字向字符串转换

toString()

这个方法可以接受转换基数, 也就是可以指定转成什么进制,默认是十进制

const a = 2
a.toString()  //'2'
a.toString(2) //'10'

toFixed()

这个方法接收参数是保留的小数位数,默认是不保留

const a = 1.2
a.toFixed() //'1'
a.toFixed(2) //'1.20'

toExponential()

适用有把数字转成成指数形式, 传递的参数是小数的位数

const a = 100.1
a.toExponential() //'1.001e+2'
a.toExponential(4) //'1.0010e+2'

toPrecision()

用于指定数字的有效位数转成字符串, 如果有效位数小于当前的为位数则转成指数形式,传入的参数表示位数, 默认为当前位数

const a = 100
a.toPrecision(2) // '1.0e+2'
a.toPrecision()  // '100'

隐式转换方法

用当前的数字加上空字符串

10 + '' //'10'

ES6模板字符串的方法

const a = 10
`${
      
      a}` // '10'
`${
      
      10}` // '10'

上面的数字转换方法,都不会改变数字的值只是把数字型转换成了,但是toFixed、toExponential、toPrecsion种方法会对数字进行四舍五入

字符串转成数字

Number

只能转换十进制的数字, 如果传入的是非数字则为NaN

Number('-2.2') // -2.2

parseInt

只解析数字整数部分舍弃小数, 遇到0x开头的当成16进制解析, 会尽力解析前置的数字忽略后面的非数字, 但如果前面是非数字返回NaN,接受第二个参数表示数字的基数

parseInt('-2.8') // -2
parseInt('2 yy') // 2
parseInt('0x11') // 17
parseInt('0x11yy') // 17
parseInt('11'2) // 3

parseFloat

可解析出数字整数部分和小数部分, 会尽力解析前置的数字忽略后面的非数字, 但如果前面是非数字返回NaN,(不能解析0x开头的十六进制,没有第二个参数作为基数)

parseInt('-2.8') // -2.8
parseFloat('11yy') // 11

隐式转换

当前数字字符串减0

'1.3' - 0  // 1.3
'-1.3' - 0  // -1.3

猜你喜欢

转载自blog.csdn.net/qq_41536505/article/details/129304402