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我也推荐只是用在一些小项目或者实验性项目中。尝鲜网址 图床

相关推荐
moxiaoran575338 分钟前
Go语言的错误处理
开发语言·后端·golang
南半球与北海道#2 小时前
前端打印(三联纸票据打印)
前端·vue.js·打印
董世昌412 小时前
深入浅出 JavaScript 常用事件:从原理到实战的全维度解析
前端
满栀5852 小时前
分页插件制作
开发语言·前端·javascript·jquery
qq_406176143 小时前
深入剖析JavaScript原型与原型链:从底层机制到实战应用
开发语言·前端·javascript·原型模式
开开心心_Every3 小时前
免费窗口置顶小工具:支持多窗口置顶操作
服务器·前端·学习·macos·edge·powerpoint·phpstorm
闲蛋小超人笑嘻嘻4 小时前
Vue 插槽:从基础到进阶
前端·javascript·vue.js
梦6504 小时前
Vue2 与 Vue3 对比 + 核心差异
前端·vue.js
tiandyoin4 小时前
给 MHTML 添加滚动条.mhtml
前端·chrome·html·mhtml
遗憾随她而去.4 小时前
前端大文件上传(切片并发/断点续传/秒传/WebWorker 计算Hash) 含完整代码
前端