溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JavaScript是不是只能寫前端

發(fā)布時(shí)間:2022-10-10 11:47:55 來源:億速云 閱讀:148 作者:iii 欄目:web開發(fā)

這篇文章主要介紹“JavaScript是不是只能寫前端”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“JavaScript是不是只能寫前端”文章能幫助大家解決問題。

JavaScript不是只能寫前端,它也可寫后端;JavaScript可以利用Node.js來實(shí)現(xiàn)后端開發(fā)。Node.js是一個(gè)讓JavaScript運(yùn)行在服務(wù)端的開發(fā)平臺(tái),是一個(gè)事件驅(qū)動(dòng)“I/O”服務(wù)端JavaScript環(huán)境,可以將Node.js理解為運(yùn)行在服務(wù)端的JavaScript,因此JavaScript可以寫在后端。

本教程操作環(huán)境:windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。

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

JavaScript可以通過Node.js技術(shù)來實(shí)現(xiàn)后端開發(fā),Node.js是一個(gè)讓JavaScript運(yùn)行在服務(wù)端的開發(fā)平臺(tái),它讓 JavaScript 成為與PHP、Python、Perl、Ruby 等服務(wù)端語言平起平坐的腳本語言。

Node.js可以讓js運(yùn)行在服務(wù)端,并借助Google v8引擎帶來性能上的飛躍,使其性能幾乎快接近于go語言。異步的編程方式讓它能夠承載巨大的并發(fā)。但是它現(xiàn)在也有如下的缺點(diǎn):

沒有類似java的Spring框架這樣有高度統(tǒng)一的開發(fā)方式; 生態(tài)還不夠完善 作為一個(gè)前端開發(fā)者想要開發(fā)后臺(tái),你可能先是被自己為難住。但是其實(shí)針對(duì)中小型系統(tǒng)來說,開發(fā)一個(gè)后臺(tái),最重要的就是熟悉“SQL”,只要掌握了這個(gè)你就算是入門 了后臺(tái)開發(fā)了。因?yàn)槠渌囊磺卸加锌蚣軒湍銣?zhǔn)備好了。

框架的選擇

目前用于后端開發(fā)的node框架有:

  • egg

  • express

  • koa

  • nest

那么我們?cè)撊绾芜x擇呢,有一個(gè)很好的方式就是看github的start,那么我們對(duì)比了下koa的start是最多的。 但是筆者這邊推薦大家使用egg,理由如下:

  • 阿里金服開發(fā)的,維護(hù)升級(jí)迭代有保障;

  • 底層基于koa;

  • 部署服務(wù)時(shí)可以很方便地使用多核心,壓榨服務(wù)器性能;

  • 豐富的插件供你選擇,你也可以自定義自己的插件;

  • 對(duì)于中小型系統(tǒng)來說不建議用nest這種類似springboot的框架,那還不如直接用springboot更加完全、健全、穩(wěn)定;

javascript 寫后端前必須要知道的事

Node 打破了 JS 只能開發(fā)前端的瓶頸,真正實(shí)現(xiàn)了得JS者得天下的壯舉!然而,做后端比做前端要嚴(yán)謹(jǐn)多,所以JS語言上的一些“BUG”是必須要知道了。別到時(shí)候數(shù)據(jù)出了問題,整的一頭霧水。

下面舉例出JS在處理數(shù)據(jù)中的一些常見問題,以及解決辦法!幫助大家鞏固JS基礎(chǔ),在工作中少走彎路。

一、浮點(diǎn)型數(shù)據(jù)失去精度問題:

浮點(diǎn)型又分為單精度浮點(diǎn)型(float)和雙精度浮點(diǎn)型(double ),在強(qiáng)類型語言中(C,JAVA)中有詳細(xì)的說明,在 JS 中統(tǒng)稱為數(shù)值型(Number)。有興趣的讀者可以去了解相關(guān)知識(shí),本文繼續(xù)回到上面的問題。

首先看一下失去精度問題的表現(xiàn)情況,源碼如下:

console.log(0.1+0.2);    //0.30000000000000004

本應(yīng)該結(jié)果是 0.3 才對(duì),可是運(yùn)行結(jié)果出現(xiàn)了迷之問題。這在后端開發(fā)中是絕對(duì)不允許存在的,這個(gè)問題不只在JS中出現(xiàn),經(jīng)測(cè)試JAVA,PHP都存在該問題,C不存在該問題。其它語言咋也沒學(xué)過??!咋也不知道啊!

說完問題,接下來說一說解決辦法,源碼如下:

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

很幸運(yùn)通過上述代碼,我們得到了想要的正確結(jié)果,但JS留給我們的問題沒有結(jié)束,請(qǐng)看下面的問題

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

toFixed() 方法使用定點(diǎn)表示法來格式化一個(gè)數(shù)值。簡(jiǎn)單點(diǎn)來說,就是對(duì)數(shù)據(jù)進(jìn)行四舍五入的處理,定點(diǎn)表示要保留的小數(shù)位數(shù)。

這個(gè)問題依舊與上一個(gè)問題 浮點(diǎn)型 數(shù)據(jù)有關(guān),看下文示例代碼:

let a=1.115;
console.log(a.toFixed(2))    //1.11

所幸小編小學(xué)數(shù)學(xué)不錯(cuò),貌似還當(dāng)過幾年數(shù)學(xué)課代表(竊喜一波),一眼就看出了,正確答案應(yīng)該是 1.12 才對(duì)。機(jī)智的小編努力尋找繞坑方法,請(qǐng)看源碼:

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

JS開發(fā)后端應(yīng)用時(shí),一定要注意這些數(shù)據(jù)異常問題。更多的問題,還請(qǐng)各位讀者自行學(xué)習(xí)啦。

代碼千萬行,基礎(chǔ)第一行?;A(chǔ)不扎實(shí),從此兩行淚。

注:代碼示例使用了 ECMAScript 2015 版本語法,如果有兼容要求的讀者,別忘了修改源碼。

代碼千萬行,兼容第一行。兼容不處理,到頭兩行淚。

關(guān)于“JavaScript是不是只能寫前端”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI