JavaScript只能写前端吗

青灯夜游
Freigeben: 2022-10-09 17:24:38
Original
2053 Leute haben es durchsucht

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
Nach dem Login kopieren

本应该结果是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
Nach dem Login kopieren

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

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

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

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

let a=1.115; console.log(a.toFixed(2)) //1.11
Nach dem Login kopieren

所幸小编小学数学不错,貌似还当过几年数学课代表(窃喜一波),一眼就看出了,正确答案应该是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
Nach dem Login kopieren

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

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

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

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

【相关推荐:web前端开发

Das obige ist der detaillierte Inhalt vonJavaScript只能写前端吗. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!