<output id="qn6qe"></output>

    1. <output id="qn6qe"><tt id="qn6qe"></tt></output>
    2. <strike id="qn6qe"></strike>

      亚洲 日本 欧洲 欧美 视频,日韩中文字幕有码av,一本一道av中文字幕无码,国产线播放免费人成视频播放,人妻少妇偷人无码视频,日夜啪啪一区二区三区,国产尤物精品自在拍视频首页,久热这里只有精品12

      js便簽筆記(14)——用nodejs搭建最簡(jiǎn)單、輕量化的http server

      1. 引言

      前端程序猿主要關(guān)注的是頁面,你可能根本就用不到.net,java,php等后臺(tái)語言。

      但是你制作出來的網(wǎng)頁總要運(yùn)行、總要測(cè)試吧?——那就免不了用到http server。我先前都是用visual studio的,雖然很好用,功能很強(qiáng)大,但是我就開發(fā)一個(gè)html、javascript、css,干嘛用這種傻大本粗的東西。打開一次特別慢,占內(nèi)存特別厲害,安裝時(shí)C盤占去好幾個(gè)G的空間。

      后來閑來無事就換成了nodejs不用安裝任何插件,只需要手動(dòng)創(chuàng)建三個(gè)小文件(總共才2KB),運(yùn)行即可,速度很快。感覺真的是非常簡(jiǎn)單、輕量化。特此分享,知道的請(qǐng)略過,不喜勿噴!

      2. 四步搭建

      第一步,安裝nodejs:

      不多廢話,到www.nodejs.org下載安裝即可。

       

      第二步,創(chuàng)建兩個(gè)js文件

      創(chuàng)建兩個(gè)js文件,分別保存為 server.js  和  mine.js ,代碼如下:

       1 var PORT = 8080;       //端口
       2 var DIR = 'test1';     //用于存放html的目錄
       3 
       4 var http = require('http');
       5 var url=require('url');
       6 var fs=require('fs');
       7 var mine=require('./mine').types;
       8 var path=require('path');
       9 
      10 var server = http.createServer(function (request, response) {
      11     var pathname = url.parse(request.url).pathname;
      12     var realPath = path.join(DIR, pathname);
      13     //console.log(realPath);
      14     var ext = path.extname(realPath);
      15     ext = ext ? ext.slice(1) : 'unknown';
      16     fs.exists(realPath, function (exists) {
      17         if (!exists) {
      18             response.writeHead(404, {
      19                 'Content-Type': 'text/plain'
      20             });
      21 
      22             response.write("This request URL " + pathname + " was not found on this server.");
      23             response.end();
      24         } else {
      25             fs.readFile(realPath, "binary", function (err, file) {
      26                 if (err) {
      27                     response.writeHead(500, {
      28                         'Content-Type': 'text/plain'
      29                     });
      30                     response.end(err);
      31                 } else {
      32                     var contentType = mine[ext] || "text/plain";
      33                     response.writeHead(200, {
      34                         'Content-Type': contentType
      35                     });
      36                     response.write(file, "binary");
      37                     response.end();
      38                 }
      39             });
      40         }
      41     });
      42 });
      43 server.listen(PORT);
      44 console.log("Server runing at port: " + PORT + ".");
      server.js
       1 exports.types = {
       2   "css": "text/css",
       3   "gif": "image/gif",
       4   "html": "text/html",
       5   "ico": "image/x-icon",
       6   "jpeg": "image/jpeg",
       7   "jpg": "image/jpeg",
       8   "js": "text/javascript",
       9   "json": "application/json",
      10   "pdf": "application/pdf",
      11   "png": "image/png",
      12   "svg": "image/svg+xml",
      13   "swf": "application/x-shockwave-flash",
      14   "tiff": "image/tiff",
      15   "txt": "text/plain",
      16   "wav": "audio/x-wav",
      17   "wma": "audio/x-ms-wma",
      18   "wmv": "video/x-ms-wmv",
      19   "xml": "text/xml"
      20 };
      mine.js

      我在桌面上新建一個(gè)“demo1”的文件夾,把這兩個(gè)創(chuàng)建好的js文件拷進(jìn)去。

       

      第三步,創(chuàng)建一個(gè).bat命令文件

      還是那個(gè)“demo1”文件夾,再在這個(gè)文件夾中創(chuàng)建一個(gè)“startServer.bat”文件,文件內(nèi)容其實(shí)就一句話:

      node server.js
      startServer.bat

      此時(shí) demo1 文件夾中就有了三個(gè)文件:

      第四步,加入你的html文件

      還是那個(gè)“demo1”文件夾,我們需要在這個(gè)文件中創(chuàng)建一個(gè)“test1”文件夾,然后我們加入一個(gè)index.html,等會(huì)兒做測(cè)試用。

      重點(diǎn)需要注意:為什么這里會(huì)有一個(gè)“test1”文件夾呢?因?yàn)槲覀兊摹皊erver.js”中配置的目錄就是“test1”。如果你看著不順眼,可以改掉,但是要保證兩者名稱一致。

      如果我們?cè)赿emo1中有好幾個(gè)測(cè)試項(xiàng)目,需要運(yùn)行哪一個(gè),可以打開“server.js”修改配置即可,非常方便。

      3. 一鍵啟動(dòng)

      經(jīng)過了上面“漫長(zhǎng)復(fù)雜”的配置過程,到這一步就簡(jiǎn)單了。

      如何“一鍵”啟動(dòng)? 大家應(yīng)該都能猜到了——startServer.bat——對(duì),雙擊運(yùn)行startServer.bat,控制臺(tái)即提示你有http server服務(wù)了。

      端口號(hào)默認(rèn)是“8080”,可以在“server.js”中修改,就在代碼第一行。

      4. 創(chuàng)建多個(gè)http server

      咱們上面說了半天,就講了如何創(chuàng)建第一個(gè)http server,其實(shí)創(chuàng)建第二個(gè)、第三個(gè)、第四個(gè)……都一樣簡(jiǎn)單。

      把 demo1 文件夾中的三個(gè)文件,考到你想要?jiǎng)?chuàng)建站點(diǎn)的位置。打開 server.js 修改一下端口號(hào)和目錄名稱,運(yùn)行startServer.bat就可以了。

      想在那里創(chuàng)建http server,就拷貝到哪里,然后運(yùn)行。不想再用http server了,直接刪掉那三個(gè)文件就行。

      簡(jiǎn)單易用!

      -------------------------------------------------------------------------------------------------------------

      歡迎關(guān)注我的微博

      也歡迎關(guān)注我的教程:

      從設(shè)計(jì)到模式深入理解javascript原型和閉包系列》《微軟petshop4.0源碼解讀視頻》《json2.js源碼解讀視頻

      支持插入代碼的富文本編輯器——wangEditor

      -------------------------------------------------------------------------------------------------------------

      posted @ 2014-12-05 08:22  王福朋  閱讀(13984)  評(píng)論(13)    收藏  舉報(bào)
      主站蜘蛛池模板: 欧美性白人极品hd| 国产成人精品视频不卡| 中文字幕少妇人妻精品| 午夜精品福利亚洲国产| 国产午夜福利视频合集| 久久综合激情网| 亚洲人成电影在线天堂色| 东台市| 丝袜老师办公室里做好紧好爽| 一本大道久久香蕉成人网| 日韩一区二区三区不卡片| 沁源县| 中文午夜乱理片无码| 韩国无码av片在线观看| 亚洲av永久无码精品成人| 亚洲女同性同志熟女| 色老板精品视频在线观看| 99九九热久久只有精品| 94人妻少妇偷人精品| 丁香五月婷激情综合第九色| 婷婷99视频精品全部在线观看 | 亚洲日本欧美日韩中文字幕| 亚洲精品国模一区二区| 俄罗斯老熟妇性爽xxxx| 亚洲国产精品久久久久4婷婷| 国产99视频精品免费视频76| 国产精品久久久久av福利动漫| 粉嫩蜜臀av一区二区绯色| 日韩精品中文字幕人妻| 又湿又紧又大又爽A视频男| 免费观看的av在线播放| japanese人妻中文字幕| 日韩丝袜亚洲国产欧美一区| 少妇被躁爽到高潮| 国产一级精品在线免费看| 国产成人亚洲综合图区| 中文字幕在线亚洲精品| 亚洲婷婷综合色香五月| 国产欧美精品一区二区三区-老狼| 成人性无码专区免费视频| 北宁市|