成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

完全面向于初學者的Node.js指南

開發 前端 開發工具
新的上班時間是周二至周六,工作之余當然要堅持學習啦。

新的上班時間是周二至周六,工作之余當然要堅持學習啦。

希望這篇文章能解決你這樣一個問題:“我現在已經下載好Node.Js了,該做些什么呢?”

原文URL:http://blog.modulus.io/absolute-beginners-guide-to-nodejs

本文的組成:上文的翻譯以及小部分自己的理解。所有文章中提到的JS代碼,都是經過測試,可運行并產生正確結果的。

What is Node.js?

關于Node.Js,要注意一點:Node.js本身并不是像IIS,Apache一樣的webserver,它是一個JavaScript 的運行環境。當我們需要搭建一個HTTP 服務器的時候,我們可以借助Node.Js提供的庫快捷的寫一個。

Installing Node

Node.js 安裝是非常方便的,如果你在用Windows or Mac,去這個頁面就可以了download page.

I've Installed Node, now what?

   以WINDOWS為例,一旦安裝好Node.Js之后,可以通過兩種不同方式來調用Node。

   方式一:CMD 下輸入node,進入交互模式,輸入一行行的JS代碼,Node.Js會執行并返回結果,例子:

  1. $ node 
  2. > console.log('Hello World'); 
  3. Hello World 
  4. undefined 

   PS:上一個例子的undefined來自于console.log的返回值。

    方式二:CMD 下輸入node 文件名(當然需要先CD到該目錄)。例子:

 

  1. hello.js 下的代碼: 
  2. console.log('Hello World'); 
  3. $ node hello.js 
  4. Hello World 

 

 

Doing Something Useful - File I/O

    使用純粹的Js原生代碼是有趣但是不利于工程開發的,Node.JS提供了一些有用的庫(modules),下面是一個使用Node.js提供的庫分析文件的例子:

 

  1. example_log.txt 
  2. 2013-08-09T13:50:33.166Z A 2 
  3. 2013-08-09T13:51:33.166Z B 1 
  4. 2013-08-09T13:52:33.166Z C 6 
  5. 2013-08-09T13:53:33.166Z B 8 
  6. 2013-08-09T13:54:33.166Z B 5 

 

    我們做的***件事情是讀出該文件的所有內容。

 

  1. my_parser.js 
  2.  
  3. // Load the fs (filesystem) module 
  4. var fs = require('fs'); 
  5.  
  6. // Read the contents of the file into memory. 
  7. fs.readFile('example_log.txt', function (err, logData) { 
  8.    
  9. // If an error occurred, throwing it will 
  10.   // display the exception and end our app. 
  11.   if (err) throw err; 
  12.    
  13. // logData is a Buffer, convert to string. 
  14.   var text = logData.toString(); 
  15. }); 

 

     filesystem (fs 的API ref) module 提供了一個可以異步讀取文件并且結束后執行回調的函數,內容以 Buffer的形式返回(一個byte數組),我們可以調用toString() 函數,將它轉換成字符串。

     現在我們再來添加解析部分的代碼。

 

  1. my_parser.js 
  2.  
  3. // Load the fs (filesystem) module. 
  4. var fs = require('fs');//  
  5.  
  6. // Read the contents of the file into memory. 
  7. fs.readFile('example_log.txt', function (err, logData) { 
  8.    
  9. // If an error occurred, throwing it will 
  10.   // display the exception and kill our app. 
  11.   if (err) throw err; 
  12.    
  13. // logData is a Buffer, convert to string. 
  14.   var text = logData.toString(); 
  15.    
  16. var results = {}; 
  17.  
  18. // Break up the file into lines. 
  19.   var lines = text.split('\n'); 
  20.    
  21. lines.forEach(function(line) { 
  22.     var parts = line.split(' '); 
  23.     var letter = parts[1]; 
  24.     var count = parseInt(parts[2]); 
  25.      
  26. if(!results[letter]) { 
  27.       results[letter] = 0
  28.     } 
  29.      
  30. results[letter] += parseInt(count); 
  31.   }); 
  32.    
  33. console.log(results); 
  34.   // { A: 2, B: 14, C: 6 } 
  35. }); 

 

Asynchronous Callbacks

    剛才的例子中使用到了異步回調,這在Node.Js編碼中是廣泛被使用的,究其原因是因為Node.Js是單線程的(可以通過某些特殊手段變為多線程,但一般真的不需要這么做)。故而需要各種非阻塞式的操作。

    這種非阻塞式的操作有一個非常大的優點:比起每一個請求都創建一個線程的Web Server。Node.Js在高并發的情況下,負載是小得多的。

Doing Something Useful - HTTP Server

    我們來運行一個HTTP server吧, 直接復制 Node.js homepage.上的代碼就可以了。

 

  1. my_web_server.js 
  2.  
  3.     var http = require('http'); 
  4.  
  5.     http.createServer(function (req, res) { 
  6.       res.writeHead(200, {'Content-Type''text/plain'}); 
  7.       res.end('Hello World\n'); 
  8.     }).listen(8080); 
  9.  
  10.     console.log('Server running on port 8080.'); 

 

    運行以上代碼之后就可以訪問http://localhost:8080 就能看到結果啦。

    上面的例子顯然過于簡單,如果我們需要建立一個真正的web server。我們需要能夠檢查什么正在被請求,渲染合適的文件,并返回。而好消息是,Express已經做到這一點了。

Doing Something Useful - Express

    Express 是一個可以簡化開發的框架。我們執行npm install 來安裝這個package。

$ cd /my/app/location
$ npm install express

    指令執行完畢后,Express相關的文件會被放到應用目錄下的node_modules文件夾中。下面是一個使用Express開發的例子:

 

  1. my_static_file_server.js 
  2.  
  3. var express = require('express'), 
  4.     app = express(); 
  5.  
  6.  
  7.  
  8. app.use(express.static(__dirname + '/public')); 
  9.  
  10. app.listen(8080); 
  11.  
  12. $ node my_static_file_server.js 

 

    這樣就建立了一個文件服務器。入油鍋我們在 /public 文件夾放了一個"my_image.png" 。我們就可以在瀏覽器輸入http://localhost:8080/my_image.png 來獲取這個圖片. 當然,Express 還提供了非常多的其它功能。

Code Organization

    剛才的例子中我們使用的都是單個文件,而實際的開發中,我們會設計到代碼如何組織的問題。

    我們試著將最開始的文字解析程序重新組織。

 

  1. parser.js 
  2.  
  3. // Parser constructor. 
  4. var Parser = function() { 
  5.  
  6. }; 
  7.  
  8. // Parses the specified text. 
  9. Parser.prototype.parse = function(text) { 
  10.    
  11. var results = {}; 
  12.    
  13. // Break up the file into lines. 
  14.   var lines = text.split('\n'); 
  15.    
  16. lines.forEach(function(line) { 
  17.     var parts = line.split(' '); 
  18.     var letter = parts[1]; 
  19.     var count = parseInt(parts[2]); 
  20.      
  21. if(!results[letter]) { 
  22.       results[letter] = 0
  23.     } 
  24.      
  25. results[letter] += parseInt(count); 
  26.   }); 
  27.    
  28. return results; 
  29. }; 
  30.  
  31. // Export the Parser constructor from this module. 
  32. module.exports = Parser; 

 

   關于這里的exports 的含義請參考我的博客:Node.Js學習01: Module System 以及一些常用Node Module.

  1. my_parser.js 
  2.  
  3. // Require my new parser.js file. 
  4. var Parser = require('./parser'); 
  5.  
  6. // Load the fs (filesystem) module. 
  7. var fs = require('fs'); 
  8.  
  9. // Read the contents of the file into memory. 
  10. fs.readFile('example_log.txt', function (err, logData) { 
  11.    
  12. // If an error occurred, throwing it will 
  13.   // display the exception and kill our app. 
  14.   if (err) throw err; 
  15.    
  16. // logData is a Buffer, convert to string. 
  17.   var text = logData.toString(); 
  18.    
  19. // Create an instance of the Parser object. 
  20.   var parser = new Parser(); 
  21.    
  22. // Call the parse function. 
  23.   console.log(parser.parse(text)); 
  24.   // { A: 2, B: 14, C: 6 } 
  25. }); 

    這樣,文字解析的部分就被抽離了出來。

Summary

    Node.js 是強大而靈活的。

 

 

 
責任編輯:王雪燕 來源: 博客園
相關推薦

2010-08-26 15:47:09

vsftpd安裝

2022-04-24 15:21:01

MarkdownHTML

2024-04-28 10:56:34

Next.jsWeb應用搜索引擎優化

2019-03-29 16:40:02

Node.js多線程前端

2013-12-20 14:47:23

ember.js

2022-07-22 13:14:57

TypeScript指南

2010-06-13 11:13:38

UML初學者指南

2022-10-10 15:28:45

負載均衡

2021-05-10 08:50:32

網絡管理網絡網絡性能

2023-07-28 07:31:52

JavaScriptasyncawait

2022-03-28 09:52:42

JavaScript語言

2023-07-03 15:05:07

預測分析大數據

2020-06-03 10:00:30

Kubernetes容器開發

2018-10-28 16:14:55

Reactreact.js前端

2022-09-05 15:36:39

Linux日志記錄syslogd

2023-02-10 08:37:28

2012-03-14 10:56:23

web app

2021-05-06 09:00:00

JavaScript靜態代碼開發

2024-12-25 08:00:00

機器學習ML管道人工智能

2014-04-01 10:20:00

開源Rails
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美四虎 | 一本色道久久综合亚洲精品高清 | 国产精品视频在线播放 | 在线黄av | 久久狠狠 | 亚洲免费一 | 天天操天天射天天 | 一道本不卡视频 | 欧美精品一区二区三区在线四季 | 精品二区视频 | 成人自拍视频 | 欧美激情精品久久久久 | 青青草在线播放 | 成人国产精品久久久 | 日本中文在线视频 | 午夜电影合集 | 视频一区二区在线观看 | 久久久精品 | 日本免费视频在线观看 | 久久久久国产精品www | 亚洲视频一区二区三区 | 国产欧美精品在线 | 国产二区在线播放 | 日韩一二区 | aaaa日韩| 中文字幕乱码一区二区三区 | 日韩电影免费在线观看中文字幕 | 九九久久久 | 久久天堂网 | 中国一级特黄真人毛片免费观看 | 成人免费视频网站在线看 | 91人人视频在线观看 | 亚洲成人免费电影 | 91精品久久久久久久久 | 久久久久国产精品 | 91欧美激情一区二区三区成人 | 久久国产精品91 | 范冰冰一级做a爰片久久毛片 | 男人的天堂久久 | 欧美1—12sexvideos | 国产 欧美 日韩 一区 |