前端通过JS将从后端接口返回的大数求和的简单实现
来源:互联网 发布:莫扎特人格问题 知乎 编辑:程序博客网 时间:2024/06/05 11:56
今天有个妹纸问了小Z一个前端JS的问题,是java后端接口返回20位的两位金额小数,发现使用parsefloat转换会有精度丢失的情况,小Z觉得是JS的数位长度限制的问题,所以按照妹纸的需求,设计一个JS函数,将被加数、加数分别拆成低位数、高位数(长度小于等于10位),然后判断低位数相加,长度如果大于10,则高位数之和加一,js代码如下:
<!DOCTYPE html><html><head> <meta charset="utf-8"/> <title>my js test</title> <style> </style></head><body style="margin:0px;border:0px"> <style> #myelement { position: absolute; left: 50px; right: 100px; } </style> <p title="testone" id="myelement">this is my element</p> <script>//第一组测试数据<!-- var firstNumber = '123856789123456789.45'; --><!-- var secondNumber = '123456789123456789.45'; -->//第二组测试数据var firstNumber = '12385678910.23';var secondNumber = '12345678910.12'; //第三组测试数据<!-- var firstNumber = '12a345678910.23'; --><!-- var secondNumber = '12345678910.12'; -->var r = largeNumberSum(firstNumber,secondNumber);alert(r);function largeNumberSum(a,b){if(isNaN(Number(a))|| isNaN(Number(b))){return null;}//根据需求,后台接口返回了20位的数,所以将被加数、加数分别拆成低位数、高位数(长度小于等于10位)var num1 = a.replace('.','');//先去掉小数点var num1Low = num1.substring(num1.length-10,num1.length);var num1High = num1.substring(0,num1.length-10);var num2 = b.replace('.','');var num2Low = num2.substring(num2.length-10,num2.length);var num2High = num2.substring(0,num2.length-10);var lowAddResult = parseFloat(num1Low) + parseFloat(num2Low);var highAddResult = parseFloat(num1High) + parseFloat(num2High);//低位数相加,长度大于10,则高位数相加的结果加一if(lowAddResult.toString().length>10){highAddResult += 1;}var tempResult = highAddResult.toString() + lowAddResult.toString().substring(1,lowAddResult.toString().length);//加入小数点var result = tempResult.substring(0,tempResult.length - 2) +'.'+tempResult.substring(tempResult.length-2,tempResult.length);return result;}; </script></body></html>
先简单的实现特定的需求,这一类型的大数求和问题还要再研究研究。
阅读全文
0 0
- 前端通过JS将从后端接口返回的大数求和的简单实现
- 前后端数据交互之通过JS实现将得到的数组通过Ajax传递到后端
- web实现一个按钮从前端到后端的简单流程
- 从ext前端发送异步请求到 struts的Action后端,并获取后端的返回信息
- 前端和后端的接口类
- 用ajax,将表单提交到后端,后端php向前端返回数组,前端通过jquery遍历
- c++单链表实现大数的求和运算
- 一个简单的js求和
- js将后端返回的数据动态添加到table中
- bootstrap table + spring + springmvc + mybatis 实现从前端到后端的表格分页
- java后端的list转成jsonArray返回前端开发
- [接口设计]从客户端的角度设计后端的接口
- 基于Node.js的微信JS-SDK后端接口实现
- asp.net 前端跟后端通过接口调用实现数据交互(含分页)
- 已知一个下载文件的后端接口,前端如何请求该接口,实现点击按钮、下载文件到本地。
- 网站开发,从需求到前端到后端到部署到申请第三方各种接口,开发下来的心得
- 经验分享-前端与后端的接口、HTML分离
- 趣图丨前端后端接口联调的时候……
- 微信小程序-开发者工具篇
- Linux学习笔记1
- wordpress “xx is not readable”
- eclipse中添加Eclipse Marketplace Client
- dlq
- 前端通过JS将从后端接口返回的大数求和的简单实现
- SpringBoot入门总结
- 《深度学习:21天实战Caffe》第一天
- Kaggle入门
- C语言(如何不使用第三个变量达到交换两个变量值的目的)
- LeetCode 66. Plus One
- Google Guava 缓存实现接口的限流
- setContentView中的源码探索(未修订)
- SpringMVC学习笔记(二)-----配置文件