摘要:是一個類似于的開發(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)行了升級。
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
摘要:異步最佳實(shí)踐避免回調(diào)地獄前端掘金本文涵蓋了處理異步操作的一些工具和技術(shù)和異步函數(shù)。 Nodejs 連接各種數(shù)據(jù)庫集合例子 - 后端 - 掘金Cassandra Module: cassandra-driver Installation ... 編寫 Node.js Rest API 的 10 個最佳實(shí)踐 - 前端 - 掘金全文共 6953 字,讀完需 8 分鐘,速讀需 2 分鐘。翻譯自...
摘要:前端打造了前端網(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...
閱讀 2896·2021-10-26 09:49
閱讀 3231·2021-10-14 09:42
閱讀 2057·2021-09-13 10:31
閱讀 2600·2019-08-30 11:13
閱讀 2972·2019-08-29 16:31
閱讀 1086·2019-08-29 13:58
閱讀 1869·2019-08-29 12:12
閱讀 3596·2019-08-26 13:48