VanityH – 面向前端渲染函数的优雅 Hyperscript DSL

VanityH -- 面向前端渲染函数的优雅 Hyperscript DSL

我开发了 VanityH,用来解决在原生 JS/TS、低代码引擎以及非 JSX 环境中编写 hyperscript 代码的痛点。

它是一个零依赖、超轻量的 DSL ,基于 Proxy 和闭包实现,把混乱嵌套的 h(tag, props, children) 写法,变成类似 SwiftUI / Flutter 那样清晰、链式调用的代码。

核心亮点

  • 告别嵌套地狱:DOM 结构一目了然
  • 完全不可变:写时复制,避免意外修改属性
  • 无黑魔法:行为明确,无隐式转换
  • 极致轻量:gzip 后仅约 600 字节
  • 全平台兼容:Vue、React、Preact、Snabbdom 及任何兼容 hyperscript 的渲染器

示例(Vue 3)

ts 复制代码
import { h } from "vue";
import createVanity from "vanity-h";

const { div, button, h1 } = createVanity(h);

const app = div.class("app").style("padding: 20px")(
  h1("VanityH Demo"),
  button.onClick(() => alert("Hello!"))("Click Me")
);

传统写法 vs VanityH

js 复制代码
// 之前
h("div", { class: "card" }, [h("button", { onClick: fn }, "Click")]);

// 之后
div.class("card")(button.onClick(fn)("Click"));

技术特点

  • 基于 Proxy + 闭包实现链式配置
  • 终结符式渲染逻辑
  • 完整 TypeScript 类型推导
  • MIT 开源协议

仓库:github.com/VanityH/van...

可在线试用:README 中附有 StackBlitz 示例

欢迎反馈:API 设计、边界场景、渲染器兼容等任何建议。

相关推荐
|晴 天|7 分钟前
Vue 3 项目错误处理实战:Vue ErrorHandler、Promise 监控、用户友好提示
前端·javascript·vue.js
Cobyte8 分钟前
8.响应式系统比对:手写 SolidJS 响应式系统
前端·javascript·vue.js
qiao若huan喜16 分钟前
13、webgl基本概念 + 绘制狮子座星空
前端·javascript·信息可视化·webgl
吴声子夜歌23 分钟前
Vue3——组件基础
前端·javascript·vue.js
Southern Wind31 分钟前
Vue 3 + Socket.io 实时聊天项目完整开发文档
前端·javascript·vue.js
qq_4198540535 分钟前
clip-path绘制倾斜角裁剪的矩形占比条;基于svg实现仪表盘弧线占比图。
前端·javascript·vue.js
神明不懂浪漫1 小时前
【第一章】HTML(一)——HTML简述及常用标签
前端·javascript·css·html·css3
英俊潇洒美少年1 小时前
React18 Hooks 项目重构为 Vue3 组合式API的坑
前端·javascript·重构
zs宝来了1 小时前
Vite 构建原理:ESBuild 与模块热更新
前端·javascript·框架
英俊潇洒美少年4 小时前
Vue2/Vue3 vue-i18n完整改造流程(异步懒加载+后端接口请求)
前端·javascript·vue.js