百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

前端框架太卷,HTMX和HVML接连踢馆HTML?其实有区别!

zhezhongyun 2024-12-06 20:49 43 浏览

前阵子给大家说了一篇关于前端架构的文章,《前端框架太多太复杂,HTMX助你回归简单编程》。有几百位同学收藏了,还蛮开心的。前端相对于后端、大数据等而言,确实太卷了,各种新框架几年一更新。github上前端新内容也很多,像HTMX就是一个不错的例子。

HTMX(Hypertext Markup eXchange)之所以受到大家的喜欢,是因为它回归到HTML本源,通过扩展HTML语法,允许开发者直接在HTML元素上使用特定属性(如hx-get, hx-post, hx-trigger等)来定义元素的行为,如数据获取、提交表单、触发事件等,大大减少了对单独JavaScript脚本的依赖,使得前端逻辑更加直观和易于维护。

此外,HTMX不强制要求特定的后端技术栈,它可以与任何能够返回HTML或JSON响应的后端服务无缝集成,无论是传统的Web框架还是现代的API服务,所以才会变得非常火。

HVML

不过,我们今天要给大家重点介绍的并不是HTMX,而是上次在评论区有一位同学提到的HVML!啥?又一个?其实当我花几天功夫完整学习了一下后,发现其实它并没有那么简单。

HVML是Hybrid Virtual Markup Language的缩写。它是由国内首个开源项目 MiniGUI 的作者魏永明提出并设计的一种通用且易学的编程语言。从定义就能看出来,HVML是编程语言,和C、JAVA,Python是一类的。但是,它的写法非常类似于HTML,也天然地能产生HTML,它是动态的可编程的HTML,产生的HTML可供浏览器(前端)显示。再不明白的话,直接看代码吧:

是不是基本一样。HVML通过PurC解释器解析执行,PurC从根元素(即 hvml 元素)开始,以深度优先的顺序执行 DOM 树。在执行 hvml 元素时,由于 target 属性的值为 html,解释器将生成一个 HTML 文档。

既然HVML能动态产生HTML,事情就不会只是这么简单,代码一运行产生固定HTML,那不就只是模板生成器了。HVML是数据驱动编程,通过基于数据的迭代、插入、更新、清除等操作,开发者不需要编写程序,或者只要少量编写程序即可动态生成最终的HTML 文档。

<!-- 获取所在地方,并截取前两位得到en或zh。-->
<hvml target="html" lang="$STR.substr($SYS.locale, 0, 2)">
    <!-- 终端打印-->
    $STREAM.stdout.writelines('Start of `Hello, world!`')
    <body>
        <h1>我的第一个 HVML 程序</h1>
				<!-- 初始化一个变量helloInVarLangs,它的值从后面的url获取。-->
        <init as "helloInVarLangs" from "file://{$SYS.cwd}/hello-world.json" />
        <iterate on $helloInVarLangs >
            <p>$?</p>
        </iterate>
    </body>
		<!-- 终端打印-->
    $STREAM.stdout.writelines('End of `Hello, world!`')
</hvml>

再比如时尚点的智能手环前端例子,能够显示当前时间、佩戴者的心跳信息等信息,手环联网后与和云端服务器交换信息。传统方式我们需要开发一个在智能手环上运行的 GUI 系统,然后和云端通讯获得数据,界面的修改完全由设备端代码负责。如果要改变界面的样式,还有升级固件。使用 HVML,则可以通过云端来控制设备的界面显示,本地端只需要渲染显示即可。

<!DOCTYPE hvml>
<hvml target="html" script="python">
    <head>
        <listen on="mqtt://foo.bar/bracelet" as="braceletInfo">
        <init as="_TIMERS" uniquely on="id">
            [
                { "id" : "clock", "interval" : 1000, "active" : "yes" },
            ]
        </init>
    </head>

    <body>
        <div class="clock" id="clock">
            <observe on="$_TIMERS" for="clock">
                <update on="#clock" textContent="$_SYSTEM.time('%H:%m')" />
            </observe>
        </div>

        <div class="heartbeat" id="heartbeat">
            <observe on="$braceletInfo" for="heartbeat">
                <update on="#heartbeat" textContent="$?.value BPM" />
            </observe>
        </div>

        <observe on="$braceletInfo">
            <choose on="$?" to="noop" by="CLASS: CDumpEvent" />
        </observe>
    </body>
</hvml>

代码设定了一个定时器,每隔1秒运行一次,更新时钟、心跳等标签内容,CDumpEvent 将所有来自MQTT的事件转储到了云端数据库中。

 <init as 'pyCode'>
'''
def find_next_prime(start):
    if start < 2:
        start = 2

    while True:
        start += 1
        for j in range(2, start + 1):
            if start % j == 0:
                break
        if j == start:
            return start
'''
</init>

我们可以非常方便地在 HVML 程序中调用 Python 模块,利用 Python 生态中的丰富软件包或模块开发自己的 HVML 应用,比如方面的例子,我们可以HVML中直接写python代码,还可以通过STEAM和pipe调用外部python脚本。

HTMX VS HVML

总的来说:HTMX 更专注于简化 Web 应用程序的交互,通过增强现有的 HTML 页面来提升用户体验,特别适合需要动态更新部分内容的场景。HVML 主要用于构建复杂的用户界面,强调层次化和可视化设计,适合需要高互动性和视觉层次的应用。

相关推荐

Qt setAttribute设置窗口属性(qt设置窗口名字)

this->resize(500,400);this->setWindowTitle("主窗口");QLabel*label=newQLabel(...

利用Axure+js创建可配置地图页面(axure制作app界面)

编辑导语:如何利用Axure实现自定义地图展示?本篇文章里,作者结合Axure与高德地图,对如何在Axure中设置相应参数、进而预览时实现自定义地图展示效果的操作流程进行了示范和总结,一起来看一下。本...

Excel如何获取所有类型的工作表,详细编程方法介绍

No.1Excel可以创建不同类型的工作表,编程中会遇到返回某一类型的工作或所有类型的工作表,对表进行操作,那么如何得到想要的工作表呢?下面介绍一个方法。首先要认识一下Sheets对象,它表示工作簿中...

VBA中的常用单元格引用方式(vba中单元格的引用方法)

VBA编程经常和“对象”打交道,其中最频繁的对象大概就是“单元格”了。(听说您还没有对象?那……我想你大概需要一份Excel,包邮988……)今天我们就来聊一下单元格的各种引用方式,比如单个单元格、行...

强烈安利试试这个!效果爆炸的漫画变身AI,火到服务器几度挤爆

金磊丰色发自凹非寺量子位报道|公众号QbitAI“排队1241人,等待2600秒……”——这届网友为了看一眼自己在动漫里的样子,可真是拼了!“始作俑者”是一款可以把人像变动漫的生成器。只...

软网推荐:为窗口控制菜单添加扩展控制命令

当我们点击Windows标准窗口(如记事本、资源管理器等)左上角的窗口控制按钮时,会弹出一个含有窗口控制基本命令的菜单,其中包括移动、大小、最小化、最大化、关闭等窗口控制命令。如果我们觉得这些命令不能...

45、VBA字典去重,两种不同的方法在实战中的运用(VBA进阶)

1、在VBA字典去重的操作中,若程序仅需要使用key值,那么无论采用哪种方法都不会有问题;但如果需要获得对应的item值,就必须根据实际需求选择合适的方法了。学VBA要知其然而知其所以然,不能似懂非懂...

Excel VBA学习笔记:合并单元格的相关操作

合并单元格,一个在工作中很常见的,但是是令写(工作表)公式和VBA代码的人都很不喜欢的东东,今天来讲讲与它相关的操作语法。1、Range("A1:B2").Merge;合并A1到B2单...

软网推荐:图片编辑 小而不凡(秽的读法)

说起图片编辑小工具,咱手边就有个“画图”软件。但是,这个工具比较简单,对于处理透明背景、应用滤镜效果、添加边框、做拼接图和全景照、图层操作等,就无能为力了。同样是小软件,PhotoPad就能满足上述需...

Android弹软键盘时之ListView的变化控制

前几天有个人问我,说在最底下有个输入框,弹出键盘时整个界面都一起跟着移动,上面的标题栏都移到上面看不到了,界面非常难看。其实这种问题一般存在于这样的界面布局中那就是,上面是标题栏,中间是Listvie...

如何将数组值传递到工作表中(怎么传数组)

【分享成果,随喜正能量】不与别人盲目攀比,自己就会悠然自得;不把人生目标定得太高,自己就会欢乐常在;不刻意追求完美,自己就会远离痛苦;不是时时苛求自己,自己就会活的自在;不每每吹毛求疵,自己就会轻轻松...

【VBA入门必备】Offset和Resize这样用,工作效率翻3倍!

大家好!今天共同学习下VBA中单元格属性Offset和Resize操作。一、Offset:单元格的"导航仪"功能说明:以当前单元格为坐标原点,灵活跳转位置语法格式:单元格.Offset...

50道阿里巴巴MySql经典面试题(附答案)

1、MySQL中有哪几种锁?1、表级锁:开销小,加锁快;不会出现死锁;锁定力度大,发生锁冲突的概率最高,并发度最低。2、行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度...

如何在Vue3项目中集成ESLint+Prettier+Stylelint+Husky?

随着前端工程化的发展,前端代码规范也显得越来越重要,所以作为一个前端对于这方面还是需要有一定的了解的。本篇文章将带大家使用ESLint+Prettier+Stylelint+Husky从零搭建一个Vi...

SpringBoot 中 Json 格式化配置(springboot json转对象)

SpringBoot针对jackson是自动化配置的,如果需要修改,也可以自定义配置。0x01:通过application.yml配置属性说明:spring.jackson.date-form...