Hono与Honox一次尝试
最近心血来潮,尝试着用Hono和Honox写了一个简单的Web应用。但是我被折磨了一顿😣。最近看到了hono+cloudflare搭建一个接口服务还是很有趣的,本想着用来搭建一个图床的服务,突然看到官网hono中可以编写jsx组件,于是来的兴趣准备尝试尝试。 
Hono是一个用于Node.js的Web框架,而Honox是Hono的实验性版本,旨在提供更好的性能和更现代的API。我尝试着用Hono和Honox写了一个简单的Web应用,结果出乎意料的好。Honox的性能比Hono更好,API也更现代,推荐给大家。
环境准备
- 安装Node.js和npm
- 创建一个新项目
- 安装Hono和Honox
- 配置D1数据库本地用SqlLite代替
- 部署cloudflare workers先把项目跑起来😊
以上的操作都没有问题,一切看起来如此的顺利😊。
槽点一
honox的文档写得不够详细,很多地方都看不太懂。
tsx
// app/routes/index.tsx
// `createRoute()` helps you create handlers
import { createRoute } from 'honox/factory'
export default createRoute((c) => {
return c.render(
<div>
<h1>Hello!</h1>
</div>
)
})
以上代码createRoute内不支持react运行时语法,比如:useEffect语法无法使用,只能使用honox的jsx语法。在请求数据的时候的时候我还傻傻的在useEffect中写fetch请求数据,结果可想而知, honox中没有useEffect,也没有useState,有的只是c.request和c.render。而正确的做法是直接调用DB的服务查询数据,直接在服务端渲染。其实这也是陷入了ssr的陷阱。但这种模式更像是传统的后端开发中前后端不分离的一种架构方式
槽点二
jwt中间件失效,按照官方文件所言在hono的是可以直接拦截鉴权逻辑的,但是在honox中却是失效的需要honox还在beta版本中的原有一些hono的配套的中间件还没有完全支持,所有我有自己写了一个鉴权的中间件逻辑
槽点三
没有配套的ui组件库,比如antd、element等,所有需要自己写样式或者使用honox的jsx语法自己写组件 不过还好他支持tailwindcss
总结
Honox都还处于beta版本,还有很多功能没有完善,但是总体来说,Honox确实为hono提供了更优雅的ui组件编写方式,结合了jsx,融入了react的语法,让后端模板语法写起来更加优雅。但是尝鲜毕竟只是尝鲜,实际生产中需要使用ssr还是推荐使用nuxt.js或者next.js。hono我也推荐只是用在一些小项目或者实验性项目中。尝鲜网址 图床