JavaScript只能写前端吗

青灯夜游
Libérer: 2022-10-09 17:24:38
original
2053 Les gens l'ont consulté

JavaScript不是只能写前端,它也可写后端;JavaScript可以利用Node.js来实现后端开发。Node.js是一个让JavaScript运行在服务端的开发平台,是一个事件驱动“I/O”服务端JavaScript环境,可以将Node.js理解为运行在服务端的JavaScript,因此JavaScript可以写在后端。

JavaScript只能写前端吗

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

JavaScript不是只能写前端,它也可写后端。

JavaScript可以通过Node.js技术来实现后端开发,Node.js是一个让JavaScript运行在服务端的开发平台,它让 JavaScript 成为与PHP、Python、Perl、Ruby 等服务端语言平起平坐的脚本语言。

Node.js可以让js运行在服务端,并借助Google v8引擎带来性能上的飞跃,使其性能几乎快接近于go语言。异步的编程方式让它能够承载巨大的并发。但是它现在也有如下的缺点:

没有类似java的Spring框架这样有高度统一的开发方式; 生态还不够完善 作为一个前端开发者想要开发后台,你可能先是被自己为难住。但是其实针对中小型系统来说,开发一个后台,最重要的就是熟悉“SQL”,只要掌握了这个你就算是入门 了后台开发了。因为其他的一切都有框架帮你准备好了。

框架的选择

目前用于后端开发的node框架有:

  • egg
  • express
  • koa
  • nest
  • 。。。

那么我们该如何选择呢,有一个很好的方式就是看github的start,那么我们对比了下koa的start是最多的。 但是笔者这边推荐大家使用egg,理由如下:

  • 阿里金服开发的,维护升级迭代有保障;
  • 底层基于koa;
  • 部署服务时可以很方便地使用多核心,压榨服务器性能;
  • 丰富的插件供你选择,你也可以自定义自己的插件;
  • 对于中小型系统来说不建议用nest这种类似springboot的框架,那还不如直接用springboot更加完全、健全、稳定;

javascript 写后端前必须要知道的事

Node 打破了 JS 只能开发前端的瓶颈,真正实现了得JS者得天下的壮举!然而,做后端比做前端要严谨多,所以JS语言上的一些“BUG”是必须要知道了。别到时候数据出了问题,整的一头雾水。

下面举例出JS在处理数据中的一些常见问题,以及解决办法!帮助大家巩固JS基础,在工作中少走弯路。

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

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

首先看一下失去精度问题的表现情况,源码如下:

console.log(0.1+0.2); //0.30000000000000004
Copier après la connexion

本应该结果是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
Copier après la connexion

很幸运通过上述代码,我们得到了想要的正确结果,但JS留给我们的问题没有结束,请看下面的问题

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

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

这个问题依旧与上一个问题 浮点型 数据有关,看下文示例代码:

let a=1.115; console.log(a.toFixed(2)) //1.11
Copier après la connexion

所幸小编小学数学不错,貌似还当过几年数学课代表(窃喜一波),一眼就看出了,正确答案应该是1.12才对。机智的小编努力寻找绕坑方法,请看源码:

const newToFixed=(value,length)=>{ let tempNum = 0; let s,temp; let s1 = value + ""; let start = s1.indexOf("."); if(s1.substr(start+length+1,1)>=5){ tempNum=1; } temp = Math.pow(10,length); s = Math.floor(value * temp) + tempNum; return s/temp; } console.log(newToFixed(1.115,2)) //1.12
Copier après la connexion

JS开发后端应用时,一定要注意这些数据异常问题。更多的问题,还请各位读者自行学习啦。

代码千万行,基础第一行。基础不扎实,从此两行泪。

注:代码示例使用了 ECMAScript 2015 版本语法,如果有兼容要求的读者,别忘了修改源码。

代码千万行,兼容第一行。兼容不处理,到头两行泪。

【相关推荐:web前端开发

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Tutoriels associés
Recommandations populaires
Derniers cours
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!