亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

NodeJS學習筆記之(Url,QueryString,Path)模塊

2019-11-20 13:24:58
字體:
來源:轉載
供稿:網友

一,開篇分析

這篇文章把這三個模塊拿來一起說,原因是它們各自的篇幅都不是很長,其次是它們之間存在著依賴關系,所以依次介紹并且實例分析。廢話不多說了,請看下面文檔:

(1),"Url模塊"

  來個小栗子:  

復制代碼 代碼如下:

 var url = require('url');
 var queryUrl = "http://localhost:8888/bb?name=bigbear&memo=helloworld" ;
 console.log(typeof url.parse(queryUrl)) ;
 console.log(url.parse(queryUrl)) ;

  運行結果: 

復制代碼 代碼如下:

 object // typeof
 
 {
     protocol: 'http:',
     slashes: true,
     auth: null,
     host: 'localhost:8888',
     port: '8888',
     hostname: 'localhost',
     hash: null,
     search: '?name=bigbear&memo=helloworld',
     query: 'name=bigbear&memo=helloworld',
     pathname: '/bb',
     path: '/bb?name=bigbear&memo=helloworld',
     href: 'http://localhost:8888/bb?name=bigbear&memo=helloworld'
 }

 加以說明如下:  

  protocol: 請求協議
  host: URL主機名已全部轉換成小寫, 包括端口信息
  auth:URL中身份驗證信息部分
  hostname:主機的主機名部分, 已轉換成小寫
  port: 主機的端口號部分
  pathname: URL的路徑部分,位于主機名之后請求查詢之前
  search: URL 的“查詢字符串”部分,包括開頭的問號。
  path: pathname 和 search 連在一起。
  query: 查詢字符串中的參數部分(問號后面部分字符串),或者使用 querystring.parse() 解析后返回的對象。
  hash: URL 的 “#” 后面部分(包括 # 符號)

 補充api:"url.format(urlObj)"
  

  作用:輸入一個 URL 對象,返回格式化后的 URL 字符串。

(2),"QueryString模塊"

  "QueryString" 模塊用于實現URL參數字符串與參數對象的互相轉換,來個栗子,如下所示:

復制代碼 代碼如下:

 var url = require('url');
 var qs = require('querystring');
 var queryUrl = "http://localhost:8888/bb?name=bigbear&memo=helloworld" ;
 queryUrl = url.parse(queryUrl).query ;
 console.log(queryUrl) ;
 console.log(qs.parse(queryUrl)) ;

  運行結果?如下:

復制代碼 代碼如下:

    name=bigbear&memo=helloworld
    {
      name: 'bigbear',
      memo: 'helloworld'
    }

  補充api:

  querystring.stringify(obj, [sep], [eq])------序列化一個對象到一個 query string。

  可以選擇是否覆蓋默認的分割符('&')和分配符('=')。            

  querystring.stringify({foo: 'bar', baz: 'qux'}, ';', ':')// 返回如下字串'foo:bar;baz:qux'

  querystring.parse(str, [sep], [eq], [options])------將一個 query string 反序列化為一個對象??梢赃x擇是否覆蓋默認的分割符('&')和分配符('=')。
  
  options對象可能包含maxKeys屬性(默認為1000),它可以用來限制處理過的鍵(key)的數量.設為0可以去除鍵(key)的數量限制.
  
  示例:querystring.parse('foo=bar&baz=qux&baz=quux&corge') // { foo: 'bar', baz: ['qux', 'quux'], corge: '' }

(3),"Path模塊"

  本模塊包含一套用于處理和轉換文件路徑的工具集。幾乎所有的方法僅對字符串進行轉換, 文件系統是不會檢查路徑是否真實有效的。

  先來一個簡單的栗子:    

復制代碼 代碼如下:

 var url = require('url');
 var qs = require('querystring');
 var path = require("path") ;
 var queryUrl = "http://localhost:8888/bb?name=bigbear&memo=helloworld" ;
 var root = path.basename(queryUrl) ;
 console.log(root) ; // bb?name=bigbear&memo=helloworld

  返回路徑中的最后一部分,以”/“分割。

復制代碼 代碼如下:

 var url = require('url');
 var qs = require('querystring');
 var path = require("path") ;
 var queryUrl = "http://localhost:8888/bb?name=bigbear&memo=helloworld" ;
 var root = path.basename(queryUrl) ;
 console.log(root) ; // bb?name=bigbear&memo=helloworld
 var ext = path.extname(root) ;
 console.log(ext || "Not Ext Name !") ; // Not Ext Name !

  由于api過多,以上只列出來了常用的幾個,大家需認真閱讀文檔。

二,綜合栗子

場景描述------服務器接到不同情況的請求,通過 “Url” 分別做不同處理,代碼如下:

 ?。?),建立”index.html“  

復制代碼 代碼如下:

 <!doctype html>
 <html>
     <head>
         <title>Bigbear</title>
         <meta content="IE=8" http-equiv="X-UA-Compatible"/>
         <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
         <style type="text/css">
             div {
                 margin-top: 50px;
                 width: 100%;
                   margin: 0px;
                 height:120px;
                 line-height:120px;
                   color:#fff;
                   font-size:22px;
                   background:#ff9900;
                 text-align: center;
             }
         </style>
         <script src="index.js"></script>
     </head>
     <body>
         <div>Hello,大熊!</div>
     </body>
 </html>

 ?。?),建立”index.js“

alert("Hello bb !") ; // 為了測試就這么一句代碼
 ?。?),建立”server.js“

復制代碼 代碼如下:

var http = require("http");
var fs = require('fs');
var url = require('url');
var path = require("path") ;
http.createServer(function(request,response) {
    var method = request.method ;
    method = method.toLowerCase() ;
    var fileName = path.basename(request.url) ;
    var extName = path.extname(fileName) ;
    var root = "./" ;
    if("get" == method){
        if(extName){
            fs.readFile("./" + fileName,"utf-8",function (error,data){
                if(error)throw error ;
                response.writeHead(200,{
                    "Content-Type": {
                         ".css": "text/css" ,
                         ".js" : "application/javascript"
                  }[extName]
                }) ;
                response.write(data) ;
                response.end() ;
            });
        }
        else{
            fs.readFile(root + "index.html","utf-8",function (error,data){
                if(error)throw error ;
                response.writeHead(200,{
                    "Content-Type" : "text/html"
                });
                response.write(data) ;
                response.end() ;
            });
        }
    }
    else if("post" == request.url){
        // handle post here
    }
}).listen(8888) ;
console.log("Web Server Running , Port On ---> 8888") ;

 
  node server.js 運行一下。

三,總結一下

(1),理解上述三個模塊之間的聯系,靈活使用 。
(2),熟練使用 "Url,QueryString,Path" 三個模塊相關的api。
(3),最后強調:理解上面例子中的代碼意圖,不斷重構,不斷總結。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产精品一区二区不卡中文| 久久精品视频在线播放| 国产69精品久久久久久| 国产精品久久久久一区二区| 国产精品电影观看| 欧美孕妇孕交黑巨大网站| 国产亚洲精品高潮| 欧美性69xxxx肥| 国产精品久久久久久久美男| 色伦专区97中文字幕| 欧美在线免费视频| 欧美极品欧美精品欧美视频| 亚洲精品videossex少妇| 欧美在线视频在线播放完整版免费观看| 欧美色道久久88综合亚洲精品| 久久久久久国产精品久久| 欧美老女人www| 成人欧美在线视频| 精品国产鲁一鲁一区二区张丽| 91在线观看免费高清完整版在线观看| 欧美亚洲一级片| 亚洲一区中文字幕在线观看| 欧美美女18p| 日日狠狠久久偷偷四色综合免费| 日韩欧美国产免费播放| 亚洲最大福利网站| 亚洲性视频网站| 亚洲激情视频网站| 久久香蕉国产线看观看av| 欧美黑人xxx| 欧美伦理91i| 欧美极品少妇xxxxⅹ免费视频| 97免费在线视频| 久久久国产成人精品| 97久久精品国产| 国产亚洲欧洲高清一区| 久久99青青精品免费观看| 最好看的2019的中文字幕视频| 久久久综合免费视频| 不卡伊人av在线播放| 亚洲一区亚洲二区| 日韩欧美一区二区三区久久| 97精品久久久中文字幕免费| 色777狠狠综合秋免鲁丝| 国产97在线观看| 国产精品久久视频| 国产网站欧美日韩免费精品在线观看| 精品国产乱码久久久久酒店| 日韩av在线网| 日韩中文字幕视频在线观看| 中文字幕9999| 91亚洲精品久久久久久久久久久久| 亚洲一级免费视频| 亚洲永久在线观看| 日韩av黄色在线观看| 成人做爰www免费看视频网站| 日本精品视频在线观看| 成人精品视频99在线观看免费| 国产成人一区二区三区小说| 97精品国产aⅴ7777| 97久久精品人人澡人人爽缅北| 不卡伊人av在线播放| 日本中文字幕久久看| 欧美性受xxxx白人性爽| 亚洲一级一级97网| 欧美色欧美亚洲高清在线视频| 性色av一区二区咪爱| 国产一区二区视频在线观看| 欧美极品少妇xxxxⅹ裸体艺术| 在线精品国产欧美| 国产精品成人品| 亚洲国产精品高清久久久| 亚洲二区在线播放视频| 欧美性猛交xxxxx水多| 国产精品美女久久久免费| 欧美午夜精品久久久久久人妖| 曰本色欧美视频在线| 伊是香蕉大人久久| 国产日韩视频在线观看| 91国产精品视频在线| 亚洲第一区在线观看| 色综合导航网站| 羞羞色国产精品| 91亚洲精品一区二区| 国产美女直播视频一区| 一区二区在线视频| 亚洲成人黄色在线| 欧美巨乳美女视频| 久久久精品影院| 久久av在线看| 欧美成年人视频网站| 亚洲qvod图片区电影| 亚洲丁香婷深爱综合| 91精品中文在线| 国产精品久久久久久久久久久久久| 亚洲精品网址在线观看| 色爱av美腿丝袜综合粉嫩av| 日韩精品在线视频观看| 在线播放国产精品| 欧美日韩亚洲一区二| 亚洲人成在线观看网站高清| 亚洲激情自拍图| 91精品久久久久久久久久| 亚洲无av在线中文字幕| 欧美韩国理论所午夜片917电影| 国产精品视频白浆免费视频| 日韩久久精品电影| 欧美黑人一级爽快片淫片高清| 伊人久久久久久久久久久久久| 国产日韩欧美日韩| 日本成熟性欧美| 国产精品永久免费| 国产精品精品国产| 久久久久成人网| 中日韩美女免费视频网站在线观看| 4438全国亚洲精品在线观看视频| 高清欧美性猛交xxxx黑人猛交| 久久男人资源视频| 日韩视频第一页| 欧美在线xxx| 国产精品第一区| 欧美又大粗又爽又黄大片视频| 91精品久久久久久久久久另类| 亚洲欧美日韩中文在线| 国产专区欧美专区| 91久久久久久久久久久久久| 久久精彩免费视频| 91天堂在线观看| 美女扒开尿口让男人操亚洲视频网站| 国产精品99蜜臀久久不卡二区| 黄色成人在线免费| 亚洲国产另类久久精品| 成人做爰www免费看视频网站| 欧美国产日韩一区二区三区| 秋霞av国产精品一区| 一区二区三区四区在线观看视频| 国自产精品手机在线观看视频| 久久91精品国产| 91久久久久久久久| 欧美日韩裸体免费视频| 日韩在线精品一区| 亚洲一区av在线播放| 一区二区三区久久精品| 日韩成人av一区| 日韩在线免费av| 久久久久国产精品免费网站| 午夜精品久久久久久久久久久久| 久久亚洲精品视频| 国产一区二区黑人欧美xxxx| 国精产品一区一区三区有限在线| 亚洲色图15p| 国产深夜精品福利| 久久久久久久久国产精品| 国产成人一区二区三区电影| 精品国产31久久久久久| 2019中文字幕在线| 日韩国产在线看| 亚洲视频网站在线观看| 日本免费在线精品| 欧美视频在线观看 亚洲欧| 成人黄色av播放免费| 成人欧美在线观看| 国产精品稀缺呦系列在线| 奇米一区二区三区四区久久|