内容简介: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.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
解构产品经理:互联网产品策划入门宝典
电子工业出版社 / 2018-1 / 65
《解构产品经理:互联网产品策划入门宝典》以作者丰富的职业背景及著名互联网公司的工作经验为基础,从基本概念、方法论和工具的解构入手,配合大量正面或负面的案例,完整、详细、生动地讲述了一个互联网产品经理入门所需的基础知识。同时,在此基础上,将这些知识拓展出互联网产品策划的领域,融入日常工作生活中,以求职、沟通等场景为例,引导读者将知识升华为思维方式。 《解构产品经理:互联网产品策划入门宝典》适合......一起来看看 《解构产品经理:互联网产品策划入门宝典》 这本书的介绍吧!