html在后端编写,javascript能写后端吗?

本文探讨了JavaScript如何通过Node.js进行后端开发,并着重分析了在JavaScript后端开发中遇到的浮点数精度丢失问题以及toFixed()方法的四舍五入误差。针对这些问题,提供了相应的解决方案,包括自定义浮点数相加函数以避免精度丢失,以及理解并合理使用toFixed()方法进行数值格式化。
摘要由CSDN通过智能技术生成

JavaScript可以写后端。JavaScript可以通过Node.js技术来实现后端开发,Node.js是一个让JavaScript运行在服务端的开发平台。

5d6e3cc46c998615.jpg

Node.js是一个让 JavaScript 运行在服务端的开发平台,它让 JavaScript 成为与PHP、Python、Perl、Ruby 等服务端语言平起平坐的脚本语言。

JavaScript写后端时出现的一些问题:

一、浮点型数据失去精度问题:

浮点型又分为单精度浮点型(float)和双精度浮点型(double ),在强类型语言中(C,JAVA)中有详细的说明,在 JS 中统称为数值型(Number)。有兴趣的读者可以去了解相关知识,本文继续回到上面的问题。

首先看一下失去精度问题的表现情况,源码如下:console.log(0.1+0.2); //0.30000000000000004

本应该结果是 0.3 才对,可是运行结果出现了迷之问题。这在后端开发中是绝对不允许存在的,这个问题不只在JS中出现,经测试JAVA,PHP都存在该问题,C不存在该问题。其它语言咋也没学过啊!咋也不知道啊!

说完问题,接下来说一说解决办法,源码如下:const floatAdd = (arg1, arg2) => {

let r1,r2,m;

try {

r1 = arg1.toString().split(".")[1].length;

} catch(e) {

r1 = 0;

}

try {

r2 = arg2.toString().split(".")[1].length;

} catch(e) {

r2 = 0;

}

m =Math.pow(10,Math.max(r1,r2));

return (arg1*m+arg2*m)/m;

};

console.log(floatAdd(0.1,0.2)); // 0.3

二、toFixed()四舍五入的BUG:

toFixed() 方法使用定点表示法来格式化一个数值。简单点来说,就是对数据进行四舍五入的处理,定点表示要保留的小数位数。

示例:let a=1.115;

console.log(a.toFixed(2)) //1.11

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值