node.js學習之路

来源:http://www.cnblogs.com/zhangym118/archive/2016/04/10/5373476.html
-Advertisement-
Play Games

(非原創) 目錄 1. Nodejs的介紹 Node.js的是建立在Chrome的JavaScript的運行時,可方便地構建快速,可擴展的網路應用程式的平臺。Node.js使用事件驅動,非阻塞I/O模型,輕量、高效,可以完美地處理時時數據,運行在不同的設備上。 1.1. 誰在用Nodejs? 從No ...


(非原創)


 

目錄

  1. Nodejs的介紹
  2. 15Nodejs應用場景
  3. Nodejs學習路線圖

 1. Nodejs的介紹

  Node.js的是建立在ChromeJavaScript的運行時,可方便地構建快速,可擴展的網路應用程式的平臺。Node.js使用事件驅動,非阻塞I/O模型,輕量、高效,可以完美地處理時時數據,運行在不同的設備上。

  1.1. 誰在用Nodejs?

  從Nodejs官方網站的企業登記頁(https://github.com/joyent/node/wiki/Projects,-Applications,-and-Companies-Using-Node),包括我們熟知的公司有LinkedIn, Yahoo, Paypal, eBay, WalmartGroupon 還有很多的中小型公司,國內的公司如雪球、淘寶、網易、百度等也都有很多項目運行在Node.js之上。

 

  這些公司不僅是嘗試在用,而且都在向Nodejs遷移。截止到20146月本文發稿時,已經有79693包在npm.org上面發佈,而且這個數字還在快速增長中。

  那麼接下來,大家肯定都會問為什麼要是用Nodejs呢?

  1.2. 為什麼要用Nodejs?

  從我使用體會來說,Node4大優勢

  • 1. Nodejs基於Javascript語言,不用再單獨新學一門陌生的語言,從而減低了學習的門檻。同時,Javascript語言在Web前端開發中至 關重要,特別HTML5的應用必須要使用,所以前後臺統一語言,不僅可以實現程式員的全棧開發,還可以統一公共類庫,代碼標準化。單憑這一 點,Nodejs就已經贏得市場的青睞了。
  • 2. Nodejs並沒有重新開發運行時環境,而是選擇了目前最快的瀏覽器內核V8做為執行引擎,保證了Nodejs的性能和穩定性。
  • 3. Nodejs的開發非常高效,而且代碼簡單,得意於Nodejs單線程機制。而Nodejs的另一個特點非同步編程,讓Nodejs處理IO密集型應用有了明顯的優勢。個人感覺,用NodejsJavaWeb開發要高效10倍,比PHP的代碼還要簡單。
  • 4. Nodejs的社區在壯大,不僅包的數量在快速增加,而且包的質量也要明顯好於其他語言的。很多明星級的包,都是簡單而靈巧的,為了開發者的使用習慣而設 計。我最常用到的工具包,如socket.io, moment.js, underscore.js, async.js, express.js, bower.js, grunt.js, forever.js…,確實在改變我以前的編程習慣。

  當然,除了我使用Nodejs的理由,很多公司也都有自己的使用理由。

  ebay選擇Nodejs的理由,可以歸納為以下4點:

  • 動態語言:開發效率非常高,並有能力構建複雜系統,如ql.io
  • 性能和I/O負載:Nodejs非常好的解決了IO密集的問題,通過非同步IO來實現。
  • 連接的記憶體開銷:每個Node.js進程可以支持超過12萬活躍的連接,每個連接消耗大約2K的記憶體。
  • 操作性:實現了Nodejs對於記憶體堆棧的監控系統。

  1.3. Nodejs不適合的領域

  每一種語言或平臺都有不擅長領域,對於Nodejs來說最不擅長的領域在於CPU和記憶體的編程操作。

  • 1. 計算密集型應用,讓JavascriptC去拼計算性能,估計是不可能贏的。
  • 2. 記憶體控制,讓JavascriptJava比較複雜數據類型定義,也是很困難的。因為Javascript的面向對象是基於JSON的,而Java是直接使用記憶體結構。所以,通過JSON序列化和反序列的過程式控制制記憶體,Javascript就已經輸了。
  • 3. 大記憶體的應用,由於V8引擎有記憶體設計的限制,32位環境中最大堆是1G64位環境中最大堆也不到2G,如果要一次讀入10G數據,對於Nodejs來說也無法實現。
  • 4. 靜態伺服器,雖然Nodejs的優勢在IO密集集應用,但是和Nginx的處理靜態資源還是有很大的差距。
  • 5. 不需要非同步的應用:比如系統管理,自行化腳本等,還是Python更順手,Nodejs的非同步調用可能會給編程帶來一些麻煩。

 2. 15個Nodejs應用場景

  我們已經對Nodejs有了初步的瞭解,接下來看看Nodejs的應用場景。

  2.1 Web開發:Express + EJS + Mongoose/MySQL

  express 是輕量靈活的Nodejs Web應用框架,它可以快速地搭建網站。Express框架建立在Nodejs內置的Http模塊上,並對Http模塊再包裝,從而實際Web請求處理的功能。

  ejs是一個嵌入的Javascript模板引擎,通過編譯生成HTML的代碼。

  mongoose MongoDB的對象模型工具,通過Mongoose框架,可以進行訪問MongoDB的操作。

  mysql 是連接MySQL資料庫的通信API,可以進行訪問MySQL的操作。

  通常用NodejsWeb開發,需要3個框架配合使用,就像Java中的SSH

 

  2.2 REST開發:Restify

  restify 是一個基於NodejsREST應用框架,支持伺服器端和客戶端。restify比起express更專註於REST服務,去掉了express中的template, render等功能,同時強化了REST協議使用,版本化支持,HTTP的異常處理。

 

  2.3 Web聊天室(IM)Express + Socket.io

  socket.io一個是基於Nodejs架構體系的,支持websocket的協議用於時時通信的一個軟體包。socket.io 給跨瀏覽器構建實時應用提供了完整的封裝,socket.io完全由javascript實現。

 

  2.4 Web爬蟲:Cheerio/Request

  cheerio 是一個為伺服器特別定製的,快速、靈活、封裝jQuery核心功能工具包。Cheerio包括了 jQuery核心的子集,從jQuery庫中去除了所有DOM不一致性和瀏覽器不相容的部分,揭示了它真正優雅的APICheerio工作在一個非常簡 單,一致的DOM模型之上,解析、操作、渲染都變得難以置信的高效。基礎的端到端的基準測試顯示Cheerio大約比JSDOM快八倍(8x)Cheerio封裝了@FB55相容的htmlparser,幾乎能夠解析任何的 HTML XML document

 

  2.5 Web博客:Hexo

  Hexo 是一個簡單地、輕量地、基於Node的一個靜態博客框架。通過Hexo我們可以快速創建自己的博客,僅需要幾條命令就可以完成。

  發佈時,Hexo可以部署在自己的Node伺服器上面,也可以部署github上面。對於個人用戶來說,部署在github上好處頗多,不僅可以省 去伺服器的成本,還可以減少各種系統運維的麻煩事(系統管理、備份、網路)。所以,基於github的個人站點,正在開始流行起來….

 

  2.6 Web論壇: nodeclub

  Node Club 是用 Node.js MongoDB 開發的新型社區軟體,界面優雅,功能豐富,小巧迅速, 已在Node.js 中文技術社區 CNode 得到應用,但你完全可以用它搭建自己的社區。

 

  2.7 Web幻燈片:Cleaver

  Cleaver 可以生成基於Markdown的演示文稿。如果你已經有了一個Markdown的文檔,30秒就可以製作成幻燈片。Cleaver是為Hacker準備的工具。

 

  2.8 前端包管理平臺: bower.js

  Bower twitter 推出的一款包管理工具,基於nodejs的模塊化思想,把功能分散到各個模塊中,讓模塊和模塊之間存在聯繫,通過 Bower 來管理模塊間的這種聯繫。

 

  2.9 OAuth認證:Passport

  Passport項 目是一個基於Nodejs的認證中間件。Passport目的只是為了登陸認證,因此,代碼乾凈,易維護,可以方便地集成到其他的應用中。Web應用 一般有2種登陸認證的形式:用戶名和密碼認證登陸,OAuth認證登陸。Passport可以根據應用程式的特點,配置不同的認證機制。本文將介紹,用戶 名和密碼的認證登陸。

 

  2.10 定時任務工具: later

  Later 是一個基於Nodejs的工具庫,用最簡單的方式執行定時任務。Later可以運行在Node和瀏覽器中。

 

  2.11 瀏覽器環境工具: browserify

  Browserify 的出現可以讓Nodejs模塊跑在瀏覽器中,用require()的語法格式來組織前端的代碼,載入npm的模塊。在瀏覽器中,調用browserify編譯後的代碼,同樣寫在<script>標簽中。

  用 Browserify 的操作,分為3個步驟。1. node程式或者模塊, 2. Browserify 預編譯成 bundle.js, 3. HTML頁面中載入bundle.js

 

  2.12 命令行編程工具:Commander

  commander 是一個輕巧的nodejs模塊,提供了用戶命令行輸入和參數解析強大功能。commander源自一個同名的Ruby項目。commander的特性:自 記錄代碼,自動生成幫助,合併短參數(“ABC”==“-A-B-C”,預設選項,強制選項​​,命令解析,提示符。

 

  2.13 Web控制台工具: tty.js

  tty.js 是一個支持在瀏覽器中運行的命令行視窗,基於node.js平臺,依賴socket.io庫,通過websocketLinux系統通信。特性:支持多 tab視窗模型; 支持vim,mc,irssi,vifm語法; 支持xterm滑鼠事件; 支持265色顯示; 支持session

 

  2.14 客戶端應用工具: node-webwit

  Node-Webkit NodeJSWebKit技術的融合,提供一個跨WindowsLinux平臺的客戶端應用開發的底層框架,利用流行的Web技術 (Node.JSJavaScriptHTML5)來編寫應用程式的平臺。應用程式開發人員可以輕鬆的利用Web技術來實現各種應用程式。Node- Webkit性能和特色已經讓它成為當今世界領先的Web技術應用程式平臺。

 

  2.15 操作系統: node-os

  NodeOS 是採用NodeJS開發的一款友好的操作系統,該操作系統是完全建立在Linux內核之上的,並且採用shellNPM進行包管理,採用NodeJS不 僅可以很好地進行包管理,還可以很好的管理腳本、介面等。目前,DockerVagrant都是採用NodeOS的首個版本進行構建的。

 

 3. Nodejs學習路線圖

  我們看到Nodejs已經被廣發地應用在各種的場景了,針對Nodejs的應用場景,我們應該如何學習Nodejs呢?

  以下內容是我整理的文檔和教程,每個軟體包對應一篇文章,大家可以根據自己的需要進行閱讀,完整的文章列表,可以查看:從零開始nodejs系列文章

  Nodejs在快速的發展著,軟體包版本升級的很快,文章有運行不通的地方請參考官方文檔解決。我也會不定期更新文章,儘量保持文章代碼的可用性。

  祝大家在Nodejs的世界里,享受開發的樂趣!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 對於多個元素同在同一行的佈局,如比較常見的是輪播。下麵我將探討這這一佈局的做法: 首先約定 結果如下: div.row div.col div.col div.col ... 做法一: 設定 的寬度為 ,然後設置 為`float:left display:inline block` 對於 , 需要清 ...
  • jquery中attr和prop的區別、 什麼時候用 attr 什麼時候用 prop 在高版本的jquery引入prop方法後,什麼時候該用prop?什麼時候用attr?它們兩個之間有什麼區別?這些問題就出現了。 關於它們兩個的區別,網上的答案很多。這裡談談我的心得,我的心得很簡單: 對於HTML元 ...
  • 向下滑動網頁的時候能夠自動載入圖片並顯示。 盛放圖片的盒子模型如下: 設置img-width為150px,然後box_img添加內邊距和陰影效果,box的外邊距為0,添加內邊距。盒子的寬度是由img-width和邊距撐開的。也就是說盒子之間是沒有間距的,但是盒子內部有一些邊距的效果。這樣在js設置位 ...
  • 內置對象:不依賴於宿主對象,在程式執行之前就已經存在。例如Object,Array和String。 今天主要學習另外兩個單體內置對象,Global和Math。 (一)Global 對象 URI編碼方法: encodeURI()方法可以對URI進行編碼,主要用於整個URI。不會對本身屬於URI的特殊字 ...
  • 場景:1 1 <div class="div1"> 2 click me div1 3 <div class="div2">click me div2</div> 4 </div> 5 6 $(".div2").on('click',function(){ 7 alert($(this).attr( ...
  • 第十一章 1、 box-sizing:border-box(讓寬度和高度包含內邊距和邊框) 2、 clear讓後面的元素顯示在浮動元素的後面 3、 z-index只對只對絕對、固定、相對定位的元素有效 4、 vertical-aligh只用於行內元素 baseline/middle/sub/supe ...
  • 一門語言好不好用,很大程度上取決於它的api是否完善,方便使用。很遺憾jqm的api不那麼好用(對比extjs,jqm依賴jquery,也許我不太熟悉jquery也會導致我覺得jqm的api不好用),所以有必要專門寫這段來記錄想api的每個模塊如何使用。模塊截圖如下 CSS Framework: j ...
  • 參考資料:Inline elements and padding 今天寫一個導航欄時遇到了一個問題:行內元素的padding-top,padding-bottom和margin-top,margin-bottom是不是真的是無效的? 接下來就這個問題將具體分析: 1.行內元素擁有盒子模型麽 答案是是 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...