你的第一条路由
当我们访问一个网站时,它会接收
- 路径,例如
/、/about或/contact - 方法,例如
GET、POST或DELETE
以确定要显示的资源,这被简单称为 "路由"。
在 Elysia 中,我们可以通过以下方式定义路由:
- 调用以 HTTP 方法命名的方法
- 路径作为第一个参数
- 处理程序作为第二个参数
typescript
import { Elysia } from 'elysia'
new Elysia()
.get('/', '你好,世界!')
.listen(3000)路由
Elysia 中的路径可以分为 3 种类型:
- 静态路径 - 硬编码字符串以定位服务器上的资源
- 动态路径 - 段可以是任何值
- 通配符 - 路径直到特定点可以是任何内容
查看 路由。
静态路径
静态路径是一个硬编码字符串,用于定位服务器上的资源。
ts
import { Elysia } from 'elysia'
new Elysia()
.get('/hello', '你好')
.get('/hi', '嗨')
.listen(3000)查看 静态路径。
动态路径
动态路径匹配某些部分并捕获值以提取额外信息。
要定义动态路径,我们可以使用冒号 : 之后跟名称。
typescript
import { Elysia } from 'elysia'
new Elysia()
.get('/id/:id', ({ params: { id } }) => id)
.listen(3000)在这里,动态路径通过 /id/:id 创建。这告诉 Elysia 捕获值为 :id 的段,例如 /id/1、/id/123、/id/anything。
查看 动态路径。
可选路径参数
我们可以通过在参数名称后添加问号 ? 来使路径参数变为可选。
typescript
import { Elysia } from 'elysia'
new Elysia()
.get('/id/:id?', ({ params: { id } }) => `id ${id}`)
.listen(3000)查看 可选路径参数。
通配符
动态路径允许捕获单个段,而通配符允许捕获路径的其余部分。
要定义通配符,我们可以使用星号 *。
typescript
import { Elysia } from 'elysia'
new Elysia()
.get('/id/*', ({ params }) => params['*'])
.listen(3000)查看 通配符。
任务
让我们回顾一下,并创建 3 条具有不同类型的路径:
Show answer
- 静态路径
/elysia,响应为"Hello Elysia!" - 动态路径
/friends/:name?,响应为"Hello {name}!" - 通配符路径
/flame-chasers/*,响应为路径其余部分。
typescript
import { Elysia } from 'elysia'
new Elysia()
.get('/elysia', '你好 Elysia!')
.get('/friends/:name?', ({ params: { name } }) => `你好 ${name}!`)
.get('/flame-chasers/*', ({ params }) => params['*'])
.listen(3000)