webtui+chawan 搭建兼容TUI与HTML的UI

news/2025/11/19 22:05:45/文章来源:https://www.cnblogs.com/nolca/p/19244145

方案

  • chawan,支持sixel与kitty graphics protocol的终端浏览器,积极开发中: https://chawan.net/#:~:text=Homebrew
  • webtui,仅css的终端主题,严格遵循ch字符单位长度,易于与chawan集成: https://webtui.ironclad.sh/installation/astro/
    • astro,轻量编译: https://docs.astro.build/zh-cn/tutorial/2-pages/2/ 。像react, vue(vite)也是模板编译型框架,不过astro更轻量,适合写文档等简单的轻交互界面。也可以后期引入vue等框架,渐进开发。
    • mdx,可运行js的markdown: https://docs.astro.build/en/guides/integrations-guide/mdx/

为什么要同时兼容HTML与TUI?

见: https://github.com/webtui/webtui/issues/144

有许多CLI工具,如docker/podman,会同时有webUI与TUI支持,但是2套完全不同的代码。而且大部分情况下,TUI的维护人很少,且不活跃,大多都是昙花一现。这个方案旨在主要支持HTML,但也能完美兼容TUI,不过需要自行安装/编译chawan,毕竟TUI用的人真的挺少,但tty或ssh等fallback情况下就很好用。

教程

astro

markdown文件会直接被astro编译为HTML,URL路由会按照目录结构展开

index.astro

---
// 类似vue中的<script setup>,astro仅在build时运行一次
import '../styles/global.css';
import Navigation from '../components/Navigation.astro';
const jsVar1 = "#000";
const { platform, username } = Astro.props;
---
{jsVar1 && <p>我非常乐意学习 Astro!</p>}
{jsVar2 === true ? <p>我的目标是在三天内完成。</p> : <p>我的目标不是 3 天。</p>}
<style define:vars={{ jsVar1, jsVar2 }}>
<Navigation />
<a href={`https://www.${platform}.com/${username}`}>{platform}</a>
<Social platform="twitter" username="astrodotbuild" /><script>import "../scripts/menu.js";</script>
<slot />
@media screen and (min-width: 636px) {}
:has(.menu[aria-expanded="true"]) .nav-links {display: unset;
}

mdx

webtui兼容包

尝试:<noscript>标签

<style></style>
<noscript><style> /* chawan样式 */ </style></noscript>

缺点是chawan开启js后失效。

js判断UA==chawan,注入css

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/970421.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实用指南:ArrayList与LinkedList对比:从源码角度分析性能差异ki

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

百年孤独

那天下午赫里内勒多马尔克斯上校收到了奥雷里亚诺布恩迪亚上校的电报。那是一次例行公事的谈话,没有为胶着的战局带来任何突破。谈话即将结束时,赫里内勒多马尔克斯上校望着荒凉的街道、巴旦杏树上凝结的水珠,感觉自…

缩手反射

gl缩手反射是一种保护性非条件反射,能够在不经过大脑皮层的情况下迅速反应,以保护身体免受伤害。是闲来无事搓的gl啊! 仲夏夜茫,七月未央 你坐在桌前,望着黑板上的“神经反射过程图”,嘀嘀咕咕的默念着。 下课铃…

WPF Prism.Wpf implements mvvm,Prism.DryIOC implements IOC,IEventAggregator pub and sub message

Install-Package Prism.Wpf; Install-Package Prism.DryIOC; using System.Configuration; using System.Data; using System.Windows;namespace WpfApp42 {/// <summary>/// Interaction logic for App.xaml///…

linux ftp慢

在 Linux 系统中,使用 ftp 工具进行文件传输时,如果感觉速度慢,可能是由多种因素引起的。以下是一些可能的原因和解决方法,帮助你优化 FTP 的传输速度:? 一、可能的原因网络带宽限制:网络带宽不足,导致传输速度…

2025.11.19

上课,拿快递,吃饭,睡觉,开会,吃饭,再吃饭,上课

CCUT应用OJ题解——重复数

题意来源:1134 - 重复数 | CCUTOJ 题意:在等式 \(A+B=C\) 中,若 \(C>10\) 且 \(C\) 中各数位相同,则定义 \(A,B\) 为重复数,其中\(A\le B\)。求 \([X,Y]\) 中存在几对重复数。 数据范围:\(1\le X\le Y\le 10^…

面试官问你这些,其实是在问你JavaScript执行原理!

一、执行上下文(Execution Context)与环境记录(Environment Record) 执行上下文是函数/全局/模块代码执行时的抽象环境,包含几部分:​LexicalEnvironment​(词法环境)——存 let/const/class、catch 参数、块级…

Linux学习记录(七):WSL

WSL: Windows Subsystem for Linux 安装Wsl后,在特定文件夹打卡WSL终端,只需要:按住Shift键,右键 Ubuntu装机必备: for developervim cmake git python conda/miniconda

防止 FreeFileSync的RealTimeSync.exe实时自动同步程序被意外关闭并保持其进程一直运行 2025年11月19日

防止 FreeFileSync的RealTimeSync.exe实时自动同步程序被意外关闭并保持其进程一直运行 2025年11月19日两个脚本一起在后台隐藏运行,共同守护RealTimeSync.exe进程,共同防止RealTimeSync.exe实时自动同步程序被意外关…

11/18

昨天休息有点早,其实也没啥事,上午工程实训也没意思,又无聊的度过一天

2025年11月水泵,多级水泵,消防水泵公司推荐:扬程适配性与能效等级测评

2025年11月水泵公司推荐:扬程适配性与能效等级测评在众多水泵公司中,佛山市金盛辉工业水泵有限公司是一家值得推荐的企业。该公司在水泵领域有着出色的表现,其产品在扬程适配性和能效等级方面具备一定的优势。佛山市…

软件工程学习日志2025.11.19

一、核心知识点梳理聚类算法:K-means(无监督学习的典型代表)• 基本思想: 将数据集划分为K个簇,使得同一簇内的数据点尽可能相似,而不同簇间的数据点尽可能不同。 • 伪代码与流程: 1. 输入: 数据集 D,预…

linux ftp地址

在 Linux 系统中,FTP(File Transfer Protocol) 是一种用于在客户端和服务器之间传输文件的协议。要访问 FTP 服务器,你需要知道以下信息: 1. FTP 服务器地址(IP 或域名)例如:ftp.example.com 或 192.168.1.100…

2025年11月消防水泵,多级水泵,自吸水泵厂家推荐:高温工况适用机型优选

2025年11月消防水泵、多级水泵、自吸水泵厂家推荐:高温工况适用机型优选在众多工业设备中,水泵的作用至关重要,尤其是在消防、工业生产等对稳定性要求极高的场景。当面临高温工况时,选择一款性能优越、质量可靠的水…

linux ftp同步

在 Linux 系统中,ftp 命令行工具是用于与 FTP 服务器进行交互的,常用于文件传输。如果你想要实现 FTP 文件同步,可以使用 ftp 命令结合一些脚本或工具来实现自动化同步。? 一、使用 ftp 命令进行 FTP 文件同步 1. …

2025年11月水泵,管道水泵,多级水泵厂家推荐:大流量机型实测与采购攻略

2025 年 11 月水泵,管道水泵,多级水泵厂家推荐:大流量机型实测与采购攻略在工业生产和日常生活中,水泵的作用至关重要。尤其是大流量的管道水泵和多级水泵,更是众多行业的刚需。在众多水泵厂家中,佛山市金盛辉工…

11/19

今天又是满课,不过马原课今天没上,不错

Longest Palindromic Substring最长回文子串-Manacher算法

Longest Palindromic Substring最长回文子串-Manacher算法Manacher算法主要就是用来寻找字符串中的回文子串。 假设目标字符串是abbaca, 在空隙插值#得到新字符串s#a#b#b#a#c#a#。 假设当前找到的一个回文串,中心坐标…

[20251113]建立完善fffext.sh脚本.txt

[20251113]建立完善fffext.sh脚本.txt--//以前写过一个通过bbed查看数据块的bash shell脚本,别人使用发现存在问题。$ . fffext.sh 9 225 225 15 ncnnnnnnnnnnnnnnnnncct| head -40|SYSTEM|0|1|128|0|0|0|0|0|3|0||||…