成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

nodejs框架koa學(xué)習(xí)

bingchen / 2326人閱讀

摘要:是一個類似于的開發(fā)框架,創(chuàng)始人也都是。的主要特點(diǎn)是,使用了的函數(shù),進(jìn)行了架構(gòu)的重新設(shè)計(jì)。這段程序的作用是監(jiān)聽端口,當(dāng)收到請求的時候,答復(fù)你應(yīng)該注意到了,我沒有只用關(guān)鍵詞。這個星號表示這個函數(shù)是一個生成器函數(shù)。

Koa 是一個類似于 Express 的Web開發(fā)框架,創(chuàng)始人也都是TJ。Koa 的主要特點(diǎn)是,使用了 ES6 的 Generator 函數(shù),進(jìn)行了架構(gòu)的重新設(shè)計(jì)。Koa 的原理和內(nèi)部結(jié)構(gòu)很像 Express,但是語法和內(nèi)部結(jié)構(gòu)進(jìn)行了升級。

一、國際慣例 hello world 1. 當(dāng)前版本1.2

npm install --save koa

2. 代碼擼起來
  let koa = require("koa");
  let app = koa();
  app.use(function*(){
      this.body = "hello xiaomo";
    });
  app.listen(8080);

如此這般我們就創(chuàng)建了一個簡單的http服務(wù)器。這段程序的作用是監(jiān)聽 8080 端口,當(dāng)收到 GET 請求的時候,答復(fù) hello xiaomo
你應(yīng)該注意到了,我沒有只用 var 關(guān)鍵詞。我使用了 let 代替。在 ES6 中這基本上就是新的 var。這改變了變量的作用域,但是我不想在這里多說。

另一件事情有些奇怪,就是我們使用關(guān)鍵詞 function*。這個星號表示這個函數(shù)是一個生成器函數(shù)。這意味著這個函數(shù)可以在運(yùn)行的時候跳出然后再跳回來。這個概念很難去表述,所以我給你舉個栗子。

  function* inc () {
   let number = 0
   while (true)
   yield number++
  }

  let test = inc()

  console.log(test.next().value) // -> 0
  console.log(test.next().value) // -> 1
  console.log(test.next().value) // -> 2

我分解一下這個程序:

inc 函數(shù)定義了一個生成器函數(shù),在每一次 while 循環(huán)中,產(chǎn)出 number 變量然后 number 變量加 1
inc 函數(shù)被指派給了變量 test
inc 函數(shù)被迭代了 3 次,第一次的時候,number 變量在函數(shù)中被初始化了。然后,這個函數(shù)進(jìn)入到了一個 while 循環(huán),在之后的迭代中這個循環(huán)也不會退出。然后 number 0 被產(chǎn)出,所以這個可以用 .value 方法接收。在后來的迭代中這個變量 number 自增了兩次。
我希望這可以幫助理解一點(diǎn)生成器的工作原理。這只是非常復(fù)雜的 ES6 中的一小部分。

但是無論如何,讓我們回到 koa。koa 非常簡單,甚至不包含一個路由。你需要在中間件生成器函數(shù)中手動做路由匹配:

  let koa = require("koa")

  let app = koa()

  // normal route
  app.use(function* (next) {
  if (this.path !== "/") {
  return yield next
  }

  this.body = "hello world"
  });

  // /404 route
  app.use(function* (next) {
  if (this.path !== "/404") {
  return yield next;
  }

  this.body = "page not found"
  });

  // /500 route
  app.use(function* (next) {
  if (this.path !== "/500") {
  return yield next;
  }

  this.body = "internal server error"
  });

  app.listen(8080)

你可以看到,我們只要用 if 就可以做路由匹配了。你是不是很疑惑在這個上下文中的 this 是什么,express 中的 req 和 res 去哪里了。其實(shí) this 綁定了大部分的 req 和 res 的函數(shù)和屬性。如果你想知道更多關(guān)于 this 的詳情,請點(diǎn)這里。

讓我們寫一個將請求中的內(nèi)容大寫的中間件:

  let koa = require("koa")

  let app = koa()

  app.use(upcaser())

  function upcaser () {
  return function* (next) {
  yield next
  this.body = this.body.toUpperCase()
  }
  }

  app.listen(8080)
我的github地址

https://github.com/qq83387856

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/79695.html

相關(guān)文章

  • node技術(shù)棧 - 收藏集 - 掘金

    摘要:異步最佳實(shí)踐避免回調(diào)地獄前端掘金本文涵蓋了處理異步操作的一些工具和技術(shù)和異步函數(shù)。 Nodejs 連接各種數(shù)據(jù)庫集合例子 - 后端 - 掘金Cassandra Module: cassandra-driver Installation ... 編寫 Node.js Rest API 的 10 個最佳實(shí)踐 - 前端 - 掘金全文共 6953 字,讀完需 8 分鐘,速讀需 2 分鐘。翻譯自...

    王偉廷 評論0 收藏0
  • Node.js + Koa2 + MySQL + Vue.js 實(shí)戰(zhàn)開發(fā)一套完整個人博客項(xiàng)目網(wǎng)站

    摘要:前端打造了前端網(wǎng)站和后臺管理系統(tǒng)。根目錄都是開發(fā)源代碼,根目錄下的文件夾下都是前端網(wǎng)站項(xiàng)目源代碼,根目錄下的文件夾下都是后臺管理系統(tǒng)的源代碼。后臺管理系統(tǒng)使用在根目錄下進(jìn)入項(xiàng)目,安裝包,執(zhí)行命令,啟動服務(wù)瀏覽器打開即可以訪問。 showImg(https://segmentfault.com/img/remote/1460000019603918); 這是個什么的項(xiàng)目? 使用 Node...

    wangxinarhat 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<