解决页面js接受Long型损失精度问题(最新解决方案)

yizhihongxing

解决页面JS接受Long型损失精度问题(最新解决方案)

在前后端分离的架构下,我们经常需要通过网络传输Long类型的数据,在前端进行处理。但是,由于JS中Number类型采用IEEE 754双精度浮点数表示,会存在精度损失的问题。而Long类型的数据更倾向于采用Java或C++等强类型语言进行处理,因此我们需要找到一种前端解决方案。

方案一:采用BigInt

BigInt是JS的一个新类型,用于表示任意长度的整数。在ES10中引入,Chrome从67版本开始支持。我们可以将Long类型数据打包为64个二进制位,通过BigInt实例化转换为JS的BigInt类型,从而避免精度损失。

function fromLong(long) {
  let buffer = new ArrayBuffer(8);
  let dataView = new DataView(buffer);
  dataView.setBigUint64(0, long);
  let low = dataView.getUint32(0);
  let high = dataView.getUint32(4);
  let result = BigInt(high * 0x100000000 + low);
  return result;
}

let longVal = 17285819855;
let bigIntVal = fromLong(longVal);
console.log(bigIntVal); // BigInt("17285819855")

方案二:采用字符串

另一个常见的方案是将Long型数据转换为字符串,比较推荐的转换方式是将数值转换为十六进制,然后进行前/后端之间的传输。前端收到后端数据后,再将字符串转换为JS中的Number类型。

let longVal = 17285819855;
// 转换为16进制字符串
let hexString = longVal.toString(16);
console.log(hexString); // "feeda22f"

// 传输过程中hexString可能会被截断
// 传输后,将hexString转换为Long
let longValFromHex = BigInt("0x" + hexString);
console.log(longValFromHex); // BigInt("17285819855")

两种方案的具体选择要根据业务需求和兼容性等方面因素综合考虑。以上是本文的完整攻略,希望能对大家有所帮助!

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:解决页面js接受Long型损失精度问题(最新解决方案) - Python技术站

(0)
上一篇 2023年5月28日
下一篇 2023年5月28日

相关文章

  • js动态设置div的值下例子

    下面让我来详细讲解“js动态设置div的值”的完整攻略。 基本概念 在开始具体的实现代码之前,我们先来了解一下这个问题的基本概念。 动态设置div的值:指的是通过JavaScript脚本代码实现在网页中的某个元素(如div)中动态设置内容,而不是直接在HTML代码中写死。 实现过程 实现动态设置div的值可以分为以下两个步骤: 1. 获取div元素 在Jav…

    JavaScript 2023年6月11日
    00
  • JSP页面跳转方法大全

    下面我详细讲解一下“JSP页面跳转方法大全”的完整攻略。 标准的JSP页面跳转方法 1.使用response.sendRedirect()方法 response.sendRedirect()方法可以用来实现重定向,具体实现就是在response对象中设置一个响应头的Location来指定新的请求路径,例如: response.sendRedirect(&qu…

    JavaScript 2023年6月11日
    00
  • JS实现的颜色实时渐变效果完整实例

    是关于JS实现的颜色实时渐变效果的攻略,这里详细讲解一下: 准备工作 首先,我们需要打开一份HTML代码,并在其中插入一个div元素,用于展示渐变颜色,在这个div中设置颜色为淡绿色(例如:background-color: #9ccc65)。 同时,我们还需要在HTML页面中引入一份JS代码,以便后续实现实时渐变效果。 实现步骤 首先,我们需要编写一个颜色…

    JavaScript 2023年6月11日
    00
  • js简单实现用户注册信息的校验代码

    下面就是关于js简单实现用户注册信息的校验代码的完整攻略。 一、需求分析 在开发一个注册功能的网站时,我们需要对用户输入的注册信息进行校验,包括以下内容: 用户名:长度在6-20之间,只能包含字母、数字、下划线。 密码:长度在6-20之间,包含至少一个大写字母、至少一个小写字母和至少一个数字。 确认密码:需要与密码一致。 邮箱:需要符合邮箱格式。 手机号码:…

    JavaScript 2023年6月10日
    00
  • javascript中字符串替换函数replace()方法与c# 、vb 替换有一点不同

    下面详细解释 JavaScript 中的字符串替换函数 replace() 方法与 C#、VB 替换的不同之处。 JavaScript 中的 replace() 方法可以接收两个参数,第一个参数是被查找的字符串,第二个参数是用来替换查找到的字符串的字符串。通过这个方法,我们可以用一个字符串替换另一个字符串中的子串。 C#、VB 中的字符串替换方法也类似,在 …

    JavaScript 2023年5月28日
    00
  • js时间日期和毫秒的相互转换

    没问题,下面就给您详细讲解”JS时间日期和毫秒的相互转换”的完整攻略。 1. 介绍 在JS中,时间和日期是常用的数据类型。通常情况下,我们需要将时间和日期转成毫秒数以进行计算或者存储,也需要将毫秒数转换为可读的时间和日期表现。 2. 时间与毫秒的转换 2.1 时间转换为毫秒数 在JS中,我们可以利用Date对象的getTime()方法来将时间转换为毫秒数。g…

    JavaScript 2023年5月27日
    00
  • js判断为空Null与字符串为空简写方法

    JS判断为空Null与字符串为空的简写方法是前端开发中常用且重要的技巧,本文将提供完整的攻略和示例演示。 JS判断为空Null的方法 判断JS变量是否为空Null,常用的方法有两种: 1. 严格相等“===”比较 使用严格相等“===”运算符判断变量是否等于null即可,样例代码如下: let variable = null; if (variable ==…

    JavaScript 2023年5月28日
    00
  • javascript学习笔记(八) js内置对象

    当我们说到 JavaScript 时,我们通常指的是这门语言所提供的内置对象。JavaScript 内置对象是在脚本编写时自动创建的对象。在这个笔记中我们将介绍 JavaScript 的一些内置对象,例如 Object,Array,Date,RegExp,Math 等。 Object 对象 Object对象是JavaScript中最基本的对象。Object对…

    JavaScript 2023年5月18日
    00
合作推广
合作推广
分享本页
返回顶部