美文网首页
在Javascript中,获取到数字超出长度问题

在Javascript中,获取到数字超出长度问题

作者: IT实战联盟Lin | 来源:发表于2017-10-12 18:08 被阅读1941次

今天给大家分享的是在Javascript中,获取到数字超出长度问题。

实战背景

刚刚收尾的一个移动端商城项目中搭建用户体系的时候,DB设计的User用户表主键ID为bigint(20) 为了达到不重复的问题 Java生成了16-20位不重复的Long类型数字串(具体生成方式也是非常复杂的)。
但是在和web前端API对接的时候发现获取到的ID和生成的不一致,导致操作用户数据的时候一直有问题,最后定位到是ID后端数据类型和Javascript中的数据类型不一致。

问题原因

JavaScript中所有的数字,无论是整数还是小数,其类型均为Number。在程序内部,Number类型的实质是一个64位的浮点数,这与Java中double类型的浮点数是一致的;因此,JavaScript中所有的数都是浮点数。遵循IEEE 754标准(浮点数算术标准),JavaScript所能表示的数值范围为正负1.7976931348623157乘以10的308次方,其最小所能表示的小数为正负5乘以10的负324次方,这两个边界值可以分别通过访问Number对象的MAX_VALUE属性和MIN_VALUE属性来获取。

对于整数,根据ECMAScript标准的要求(http://ecma262-5.com/ELS5_HTML.htm#Section_8.5),JavaScript能表示并进行精确算术运算的整数范围为:正负2的53次方,也即从最小值-9007199254740992到最大值+9007199254740992之间的范围;对于超过这个范围的整数,JavaScript依旧可以进行运算,但却不保证运算结果的精度。值得注意的是,对于整数的位运算(比如移位等操作),JavaScript仅支持32位整型数,也即从-2147483648到+2147483647之间的整数。

我们可以浏览器中测试一下,如下操作
image.png

如上图所示 是正常的,那么我们再 +1 试试

image.png

看到了吧? 都变了!!!!

解决方案1
数据库设计的时候用varchar(20),那么会映射为String类型,就不会出现这种问题
解决方案2
如果项目已经成型并且修改数据库会造成不可预料的问题那么可以在User对象中再增加一个String类型id映射字段,如下
    private Long userId;
    
    private String userIdStr;

    public String getUserIdStr() {
        return this.userId+"";
    }

    public void setUserIdStr(String userIdStr) {
        this.userIdStr = userIdStr;
    }

那么和前端交互的时候可以使用userIdStr字段 因为是String 类型的,规避掉这个问题。

以后在设计的时候记得不要再犯这样的问题哦!

欢迎大家一起来讨论关于Java Web开发过程中好玩的问题哦,也可以投稿至yundianzixun@163.com谢谢大家支持!

相关文章

  • 2019-05-21

    在Javascript中,获取到数字超出长度问题 今天给大家分享的是在Javascript中,获取到数字超出长度问...

  • 在Javascript中,获取到数字超出长度问题

    今天给大家分享的是在Javascript中,获取到数字超出长度问题。 实战背景 刚刚收尾的一个移动端商城项目中搭建...

  • JavaScript截取中英文混杂的字符串

    JavaScript截取中英文混杂的字符串 问题描述 比如获取到微信的昵称之后,如果不能超过8个长度的汉字,超过之...

  • 移动端dpr

    例子: 在javascript中,可以通过window.devicePixelRatio获取到当前设备的dpr。在...

  • JavaScript基础 数字类型

    JavaScript 数字类型 目前有两种类型: number BigInt 是表示任意长度的整数 数字的三个特殊...

  • Math.js 一个广泛的数学库

    Math.js 专门为 JavaScript 和 Node.js 提供的一个广泛的数学库。支持数字,大数字(超出安...

  • javascript数组中数字和非数字下标的区别

    javascript数组中数字和非数字下标的区别 因为在之前看多的许多JavaScript书籍中,都宣称js是可以...

  • 剑指offer Q3 数组中重复的数字

    数组中重复数字的问题,这道题考虑的是数组中的数字在一定的范围中,大致有两种情况: 1.数组长度大于等于数字的范围如...

  • CSS文本超出部分处理

    文本超出部分该怎么处理 这个问题比较宽泛,那么就用几个实际情景来阐述吧。 情景一:文字在超出长度时,如何实现用省略...

  • 数组中重复的数字

    一、问题 找出数组中重复的数字。在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中...

网友评论

      本文标题:在Javascript中,获取到数字超出长度问题

      本文链接:https://www.haomeiwen.com/subject/yaeoyxtx.html