Hono与Honox一次尝试

Hono与Honox一次尝试

最近心血来潮,尝试着用Hono和Honox写了一个简单的Web应用。但是我被折磨了一顿😣。最近看到了hono+cloudflare搭建一个接口服务还是很有趣的,本想着用来搭建一个图床的服务,突然看到官网hono中可以编写jsx组件,于是来的兴趣准备尝试尝试。

Hono是一个用于Node.js的Web框架,而Honox是Hono的实验性版本,旨在提供更好的性能和更现代的API。我尝试着用Hono和Honox写了一个简单的Web应用,结果出乎意料的好。Honox的性能比Hono更好,API也更现代,推荐给大家。

环境准备

  1. 安装Node.js和npm
  2. 创建一个新项目
  3. 安装Hono和Honox
  4. 配置D1数据库本地用SqlLite代替
  5. 部署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语法无法使用,只能使用honoxjsx语法。在请求数据的时候的时候我还傻傻的在useEffect中写fetch请求数据,结果可想而知, honox中没有useEffect,也没有useState,有的只是c.requestc.render。而正确的做法是直接调用DB的服务查询数据,直接在服务端渲染。其实这也是陷入了ssr的陷阱。但这种模式更像是传统的后端开发中前后端不分离的一种架构方式

槽点二

jwt中间件失效,按照官方文件所言在hono的是可以直接拦截鉴权逻辑的,但是在honox中却是失效的需要honox还在beta版本中的原有一些hono的配套的中间件还没有完全支持,所有我有自己写了一个鉴权的中间件逻辑

槽点三

没有配套的ui组件库,比如antdelement等,所有需要自己写样式或者使用honoxjsx语法自己写组件 不过还好他支持tailwindcss

总结

Honox都还处于beta版本,还有很多功能没有完善,但是总体来说,Honox确实为hono提供了更优雅的ui组件编写方式,结合了jsx,融入了react的语法,让后端模板语法写起来更加优雅。但是尝鲜毕竟只是尝鲜,实际生产中需要使用ssr还是推荐使用nuxt.js或者next.jshono我也推荐只是用在一些小项目或者实验性项目中。尝鲜网址 图床

相关推荐
林小帅5 小时前
【笔记】OpenClaw 架构浅析
前端·agent
林小帅6 小时前
【笔记】OpenClaw 生态系统的多语言实现对比分析
前端·agent
程序猿的程6 小时前
开源一个 React 股票 K 线图组件,传个股票代码就能画图
前端·javascript
不爱说话郭德纲6 小时前
告别漫长的HbuilderX云打包排队!uni-app x 安卓本地打包保姆级教程(附白屏、包体积过大排坑指南)
android·前端·uni-app
唐叔在学习7 小时前
[前端特效] 左滑显示按钮的实现介绍
前端·javascript
点光7 小时前
使用Sentinel作为Spring Boot应用限流组件
后端
用户5282290301807 小时前
【学习笔记】ECMAScript 词法环境全解析
前端
青青家的小灰灰7 小时前
React 架构进阶:自定义 Hooks 的高级设计模式与最佳实践
前端·react.js·前端框架
Angelial7 小时前
Vite 性能瓶颈排查标准流程
前端
不要秃头啊7 小时前
别再谈提效了:AI 时代的开发范式本质变了
前端·后端·程序员