内容简介:As first adopters tinker with Deno, many people are trying to figure out tooling that parallels what they’re used to in node. If you’re looking for a lightweight web application framework like express.js, you probably want to explore
As first adopters tinker with Deno, many people are trying to figure out tooling that parallels what they’re used to in node. If you’re looking for a lightweight web application framework like express.js, you probably want to explore oak .
Note:Many of the examples in this post are taken from the github documentation!
What is Oak?
Oak is self-described as “A middleware framework for Deno’s http server, including a router middleware.”
To be completely transparent, oak is actually much more similar to koa for node than express.js, but express users should be very comfortable with oak.
Creating a Hello World App with Oak
To create a “Hello World!” app in deno with oak, we import Application
from the oak module. You create a new instance of the app, add a handler for all requests that set the response body to "Hello World!"
, and then listen on a port.
Make sure to pin down the version of oak in your import statement! Here it’s pinned down to version 4.0.0.
import { Application } from 'https://deno.land/x/oak@v4.0.0/mod.ts';
const app = new Application();
app.use(ctx => {
ctx.response.body = 'Hello World!';
});
await app.listen({ port: 8000 });
Now if you browse to http://localhost:8000
, you should see our Hello world!
message!
Adding Routes
Oak includes a router as well! Simply import the Router
, create a new instance of it, specify your routes, and then make sure to add it as middleware to your app.
import { Application, Router } from 'https://deno.land/x/oak/mod.ts';
const books = new Map<string, any>();
books.set('1', {
id: '1',
title: 'The Hound of the Baskervilles',
author: 'Conan Doyle, Author',
});
const router = new Router();
router
.get('/', context => {
context.response.body = 'Hello world!';
})
.get('/book', context => {
context.response.body = Array.from(books.values());
})
.get('/book/:id', context => {
if (context.params && context.params.id && books.has(context.params.id)) {
context.response.body = books.get(context.params.id);
}
});
const app = new Application();
app.use(router.routes());
app.use(router.allowedMethods());
await app.listen({ port: 8000 });
Note the helpful router.allowedMethods()
middleware, which will let clients know when a route is not allowed!
Onward!
This should hopefully get you underway! There is much more functionality available in oak, but now that you know the solution to persue and have had a basic primer, you should be able to go from here.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
实战移动互联网营销
江礼坤 / 机械工业出版社 / 2016-1 / 79.00
移动互联网的兴起,又为企业带来了新的挑战与机遇!越来越多的人,看到了移动互联网的价值与前景,但是在具体操作时,移动互联网具体如何玩?企业如何向移动互联网转型?如何通过移动互联网做营销?等等一系列问题,接踵而至。虽然目前相关的资料和文章很多,但是都过于零散,让人看完后,还是无从下手。而本书旨在成为移动互联网营销领域标准的工具书、参考书,为大家呈现一个系统、全面的移动互联网营销体系。让大家从思维模式到......一起来看看 《实战移动互联网营销》 这本书的介绍吧!