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

相关推荐
Moment2 小时前
历史性突破!LCP 和 INP 终于覆盖所有主流浏览器,iOS 性能盲点彻底消失
前端·javascript·面试
踏浪无痕2 小时前
夜莺告警引擎内核:一个优雅的设计
运维·后端·go
a努力。2 小时前
京东Java面试:如何设计一个分布式ID生成器
java·分布式·后端·面试
菩提小狗2 小时前
第2天:基础入门-Web应用&架构搭建&漏洞&HTTP数据包&代理服务器|小迪安全笔记|网络安全|
前端·安全·架构
咖啡の猫2 小时前
Python集合生成式
前端·javascript·python
superman超哥2 小时前
Rust 复合类型:元组与数组的内存布局与性能优化
开发语言·后端·性能优化·rust·内存布局·rust复合类型·元组与数组
QT 小鲜肉2 小时前
【Linux命令大全】001.文件管理之mtoolstest命令(实操篇)
linux·运维·前端·笔记·microsoft
计算机毕设指导62 小时前
基于Django的本地健康宝微信小程序系统【源码文末联系】
java·后端·python·mysql·微信小程序·小程序·django
holeer2 小时前
React UI组件封装实战——以经典项目「个人博客」与「仿手机QQ」为例
前端·javascript·react.js·ui·前端框架·软件工程