如何为markdown表格添加自定义交互

前言

目前各家公司的大模型应用如火如荼,除了大模型算法应答能力外,在前端交互上也有差异化展示。 期望在模型输出markdown文本的表格时,能展示如下的表格样式与交互:

表格样式可以通过css处理,但是表头上面的标题+按钮需要新增dom元素和js操作。

通常情况下,会想到在渲染表格后通过dom接口添加新的dom元素满足交互,稍显复杂,也不利于代码维护。而且模型输出,同一个页面上也可以存在多个表格,如果能抽离成组件使用,每个表格各自维护状态,互不影较好。

提到组件编写,可以采用笔者使用webcomponent编写的自定义表格组件👉my-tableWeb Component用得少?在大模型中寻找使用场景,里面包含了表格样式、交互、以及状态维护。

my-table组件编写完成且已完成注册,接下来就考虑如何与模型输出的markdown表格渲染关联使用。

markdown解析器

采用marked.js解析器:marked.js.org

按照文档将引入项目内,由于我们需要对表格进行扩展,因此是针对表格渲染时处理,return返回的就是对应的表格html。

js 复制代码
marked.use({
    renderer: {
        table(token){
            return '<table>xxx</table>'
        }
    }
})

拓展表格交互

按照my-table表格组件的入参,将marked.js解析生成的表格html放在my-table标签包裹即可。

由于renderer函数是重写的,因此原有生成table的富文本也需要重写,当然不是让人从无到有地重写,这一点可以查阅marked.js源码,复制原有的table renderer富文本格式,再使用my-table标签包裹,一并return返回。

这是marked.js中table renderer的源码(查阅GitHub:marked.js):

把table render的代码复制一份再稍微调整一下语言,最终return时使用自定义组件my-table:

js 复制代码
marked.use({
    renderer: {
        table(token){
            let header = '';

            // header
            let cell = '';
            for (let j = 0; j < token.header.length; j++) {
              cell += this.tablecell(token.header[j]);
            }
            header += this.tablerow({ text: cell });

            let body = '';
            for (let j = 0; j < token.rows.length; j++) {
              const row = token.rows[j];

              cell = '';
              for (let k = 0; k < row.length; k++) {
                cell += this.tablecell(row[k]);
              }

              body += this.tablerow({ text: cell });
            }
            if (body) body = `<tbody>${body}</tbody>`;
            // 这里使用自定义组件my-tabel包裹原来的table文本
            return `
                <my-table>
                    <table>
                        <thead>${header}</thead>
                        ${body}
                    </table>
                </my-table>
            `;
        }
    }
})

经过重写table renderer的处理,解析输出的表格富文本自带了my-table标签,在页面渲染时能直接渲染出对应的样式与交互。

通过webcomponent编写的表格浏览器原生支持,不用考虑前端技术栈。

最后

markdown文本输出的富文本添加自定义的样式与交互是很常见的操作,每个平台的主题风格、产品要求不尽相同。

文中提到的表格交互是比较复杂一点的,抽离成组件维护。一般场景没有这么复杂,没必要抽离组件,就在renderer函数对应标签重新输出,或者为markdown渲染的html提供css文件即可。

相关推荐
User_芊芊君子1 小时前
CANN数学计算基石ops-math深度解析:高性能科学计算与AI模型加速的核心引擎
人工智能·深度学习·神经网络·ai
小白|1 小时前
CANN与联邦学习融合:构建隐私安全的分布式AI推理与训练系统
人工智能·机器学习·自动驾驶
艾莉丝努力练剑1 小时前
hixl vs NCCL:昇腾生态通信库的独特优势分析
运维·c++·人工智能·cann
梦帮科技1 小时前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
程序员泠零澪回家种桔子1 小时前
Spring AI框架全方位详解
java·人工智能·后端·spring·ai·架构
Echo_NGC22371 小时前
【FFmpeg 使用指南】Part 3:码率控制策略与质量评估体系
人工智能·ffmpeg·视频·码率
纤纡.1 小时前
PyTorch 入门精讲:从框架选择到 MNIST 手写数字识别实战
人工智能·pytorch·python
大大大反派2 小时前
CANN 生态中的自动化部署引擎:深入 `mindx-sdk` 项目构建端到端 AI 应用
运维·人工智能·自动化
程序猿追2 小时前
深度解读 AIR (AI Runtime):揭秘 CANN 极致算力编排与调度的核心引擎
人工智能
2601_949593652 小时前
深入解析CANN-acl应用层接口:构建高效的AI应用开发框架
数据库·人工智能