JS中int类型数字超过最大值的问题及解决方案

 更新时间:2026年03月17日 15:41:13   作者:心之所向_gp  
文章主要讲述了一个在项目中遇到的数字类型ID在页面操作时查不到数据的问题,并通过将数字类型的ID转成字符串后再传入后台解决了问题,原因是JavaScript能表示并进行精确算术运算的整数范围有限,对于超过该范围的整数,JavaScript在进行运算时可能会失去精度

问题

在项目中遇到一个奇怪的问题,我们在后台获取到一个id是数字类型的,然后再进行页面操作时通过这个id去查其所绑定的数据时,一直查不到数据后台报错;

问题原因

后面经过自己的对id的比对之后发现我们获取到的id与传给后台的值竟然是不一样

解决办法

在获取到数字类型的id之后先将id转成字符串再传入后台,问题就解决了。

 data() {
    return {
      number: 59588178895489589,
    };
  },
  created() {
    console.log(this.number)
  },

原因分析:

我们可以看到上面我给的这个number赋值是:59588178895489589,而我们再浏览器打印出来的却是:59588178895489590;其实如果我们用了ESLINK是会有提示的。

因为根据ECMAScript标准的要求,JS能表示并进行精确算术运算的整数范围为:正负2的53次方,也即从最小的值-9007199254740992到最大的值9007199254740992之间的范围;虽然对于超过这个范围的整数,JavaScript依旧可以进行运算,但却不保证运算结果的精度。

值得注意的是:

对于整数的位运算(比如移位等操作),JavaScript仅支持32位整型数,也即从-2147483648到+2147483647之间的整数

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • js仿黑客帝国字母掉落效果代码分享

    js仿黑客帝国字母掉落效果代码分享

    这篇文章主要展示了js仿黑客帝国字母掉落效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-08-08
  • JS创建或填充任意长度数组的小技巧汇总

    JS创建或填充任意长度数组的小技巧汇总

    在JavaScript 中,我们往往会遇到需要使用某些默认值来填充数组的情况,那么都有哪些方式可以完成这样的任务呢?这篇文章主要给大家介绍了关于JS创建或填充任意长度数组的小技巧,需要的朋友可以参考下
    2021-10-10
  • JS简单实现城市二级联动选择插件的方法

    JS简单实现城市二级联动选择插件的方法

    这篇文章主要介绍了JS简单实现城市二级联动选择插件的方法,涉及javascript实现select遍历与设置技巧,非常简单实用,需要的朋友可以参考下
    2015-08-08
  • 微信小程序日期时间选择器使用方法

    微信小程序日期时间选择器使用方法

    这篇文章主要为大家详细介绍了微信小程序日期时间选择器的使用方法,自定义精确到分秒或时段,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • echarts大屏字体自适应的方法步骤

    echarts大屏字体自适应的方法步骤

    这篇文章主要介绍了echarts大屏字体自适应的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • 在uni-app中踩过的坑及解决

    在uni-app中踩过的坑及解决

    这篇文章主要介绍了在uni-app中踩过的坑及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • 微信小程序的线程架构【推荐】

    微信小程序的线程架构【推荐】

    这篇文章主要介绍了微信小程序的线程架构,每个小程序包含一个描述整体程序的app实例和多个描述页面的page,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-05-05
  • 三剑客:offset、client和scroll还傻傻分不清?

    三剑客:offset、client和scroll还傻傻分不清?

    这篇文章主要给大家介绍了三剑客:offset,client和scroll的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • 微信小程序实现点击文字页面跳转功能【附源码下载】

    微信小程序实现点击文字页面跳转功能【附源码下载】

    这篇文章主要介绍了微信小程序实现点击文字页面跳转功能,涉及navigator导航组件的简单使用技巧,并附带源码供读者下载参考,需要的朋友可以参考下
    2017-12-12
  • js动态实现表格添加和删除操作

    js动态实现表格添加和删除操作

    这篇文章主要为大家详细介绍了js动态实现表格添加和删除操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04

最新评论