首页 > 代码库 > 数值类型小数点后是否可以接零问题

数值类型小数点后是否可以接零问题

有些情况下,我们需要数据的精准性,小数部分或多或少要保留几位。而恰巧为整数时,我们需要将整数也加上小数点然后接0的形式来表示。

js中,我们常使用 input 框绑定数值变量的形式来提供展示或修改数据,那么大家一定会遇到一种情况:当变量为 number 类型时,你在输入框输入 .0 的形式时,底层会自动的将 .0省略,只保存了输入的整数部分。导致有些功能需要几位小数结尾而展现不出来的情况。

明明存的时候给的 .0 ,为什么到展示时却消失了?明明输入的是 .0 的形式,为什么存储后再取出来,就变成了整数呢?

js 是弱类型语言,它的核心库中没有 decimal 类型,.0 会被当成无意义的存在而省略。所以我们为了实现 .0 这样的效果,通常会将其变成字符串进行存储,js 中也封装了对应 api ,比如说 toFixed() ,底层也是以字符串进行存储实现的,所以,再有 input 框绑定的 number 类型变量的时候,想要达到 .0 形式,果断变 string 吧,number 是存不住的。

不过后台就另说了。java 中,可以拥有 .0 存在的数值类型变量,没有听错嗷,直接存储 .0 形式的变量。

java 的语言很严格,所以规定了 float(单精度)、double(双精度)类型来存储浮点数,float 变量存储时,值为 10.0f 格式(注意结尾要加上f);double 可以直接存储设置的任何小数值。两者区别在于存储大小的不同:float 单精度类型每个变量占4个字节,用 32 位 2 进制数来描述;double 则占 8 字节 64 位 2 进制数来描述。对于实际开发中来说,double 精度高,有效数字 16 位,float 精度则为 7 位。使用时考虑值的范围选用适当类型即可。

知识略薄,欢迎吐槽。

数值类型小数点后是否可以接零问题