聽說node.js很火?那麼這skr什麼鬼東西?

浮生半日鹹發表於2019-09-05

Node.js 是一個基於 Chrome V8 引擎的 JavaScript 執行環境。 Node.js 使用了一個事件驅動、非阻塞式 I/O 的模型。
Node 是一個讓 JavaScript 執行在服務端的開發平臺,它讓 JavaScript 成為與PHP、Python、Perl、Ruby 等服務端語言平起平坐的指令碼語言。釋出於2009年5月,由Ryan Dahl開發,實質是對Chrome V8引擎進行了封裝。
Node對一些特殊用例進行優化,提供替代的API,使得V8在非瀏覽器環境下執行得更好。V8引擎執行Javascript的速度非常快,效能非常好。Node是一個基於Chrome JavaScript執行時建立的平臺, 用於方便地搭建響應速度快、易於擴充套件的網路應用。Node 使用事件驅動, 非阻塞I/O 模型而得以輕量和高效,非常適合在分散式裝置上執行資料密集型的實時應用。

特性:
V8引擎本身使用了一些最新的編譯技術。這使得用Javascript這類指令碼語言編寫出來的程式碼執行速度獲得了極大提升,又節省了開發成本。對效能的苛求是Node的一個關鍵因素。 Javascript是一個事件驅動語言,Node利用了這個優點,編寫出可擴充套件性高的伺服器。Node採用了一個稱為“事件迴圈(event loop)”的架構,使得編寫可擴充套件性高的伺服器變得既容易又安全。提高伺服器效能的技巧有多種多樣。Node選擇了一種既能提高效能,又能減低開發複雜度的架構。這是一個非常重要的特性。併發程式設計通常很複雜且佈滿地雷。Node繞過了這些,但仍提供很好的效能。
Node採用一系列“非阻塞”庫來支援事件迴圈的方式。本質上就是為檔案系統、資料庫之類的資源提供介面。向檔案系統傳送一個請求時,無需等待硬碟(定址並檢索檔案),硬碟準備好的時候非阻塞介面會通知Node。該模型以可擴充套件的方式簡化了對慢資源的訪問, 直觀,易懂。尤其是對於熟悉onmouseover、onclick等DOM事件的使用者,更有一種似曾相識的感覺。
雖然讓Javascript執行於伺服器端不是Node的獨特之處,但卻是其一強大功能。不得不承認,瀏覽器環境限制了我們選擇程式語言的自由。任何伺服器與日益複雜的瀏覽器客戶端應用程式間共享程式碼的願望只能通過Javascript來實現。雖然還存在其他一些支援Javascript在伺服器端 執行的平臺,但因為上述特性,Node發展迅猛,成為事實上的平臺。
在Node啟動的很短時間內,社群就已經貢獻了大量的擴充套件庫(模組)。其中很多是連線資料庫或是其他軟體的驅動,但還有很多是憑他們的實力製作出來的非常有用的軟體。

Node的優點:
Node作為一個新興的前端框架,後臺語言,有很多吸引人的地方:
RESTful API
單執行緒
Node可以在不新增額外執行緒的情況下,依然可以對任務進行併發處理 —— Node.js是單執行緒的。
它通過事件迴圈(event loop)來實現併發操作,對此,我們應該要充分利用這一點 —— 儘可能的避免阻塞操作,取而代之,多使用非阻塞操作。
非阻塞IO
V8虛擬機器
事件驅動

模組:
Node使用Module模組去劃分不同的功能,以簡化應用的開發。Modules模組有點像C++語言中的類庫。每一個Node的類庫都包含了十分豐富的各類函式,比如http模組就包含了和http功能相關的很多函式,可以幫助開發者很容易地對比如http,tcp/udp等進行操作,還可以很容易的建立http和tcp/udp的伺服器。
要在程式中使用模組是十分方便的,只需要如下:
在這裡,引入了http類庫,並且對http類庫的引用存放在http變數中了。這個時候,Node會在我們應用中搜尋是否存在node_modules的目錄,並且搜尋這個目錄中是否存在http的模組。如果Node.js找不到這個目錄,則會到全域性模組快取中去尋找,使用者可以通過相對或者絕對路徑,指定模組的位置,比如:
var myModule = require(’./myModule.js’);
模組中包含了很多功能程式碼片斷,在模組中的程式碼大部分都是私有的,意思是在模組中定義的函式方法和變數,都只能在同一個模組中被呼叫。當然,可以將某些方法和變數暴露到模組外,這個時候可以使用exports物件去實現。

node.js的hello world框架:

var http=require('http');
server=http.createServer(function(req,res){
res.writeHeader(200,{"Content-Type":"text/plain"});
res.end("hello world");
});
server.listen(8000);
console.log("http start @8000");

相關文章