思源笔记折腾记录 - 表格式嵌入块

本贴最后更新于 807 天前,其中的信息可能已经时移俗易

嵌入块表格.gif

嵌入块表格 1.gif

表格式嵌入块呢,顾名思义就是把嵌入块渲染成表格的样式。

也就是说呢,就是看起来像一个表格的嵌入块。

或者说是在嵌入块里面的表格。

那么为什么要有表格式嵌入块呢?

因为有用户说有的时候嵌入块显示成表格的样式比较好,那么聪明的你知道为什么有人要把嵌入块显示成表格呢?

我也很好奇这个问题,简单了解了一下就是在有些情况下需要把嵌入块显示成表格,所以就需要有一个表格式嵌入块的功能。

所以表格式嵌入块的情况就是这样了,原理也还比较简单,直接上代码码吧,代码片段有风险,玩脱了别找我麻烦嗷

import { Model } from "./model.js"; import { 重渲染配置表 } from "./replace.js"; setTimeout(渲染所有嵌入块表格, 1000); new Model().all(() => { setTimeout(渲染所有嵌入块表格, 500); }); setInterval(渲染所有嵌入块表格, 5000); async function 渲染所有嵌入块表格() { let 嵌入块列表 = document.querySelectorAll( '[data-type="NodeBlockQueryEmbed"]' ); 嵌入块列表.forEach((嵌入块元素) => { try { 渲染表格(嵌入块元素); } catch (e) { console.error(e); } }); } async function 渲染表格(嵌入块元素) { let sql = 嵌入块元素.getAttribute("data-content"); let id = 嵌入块元素.getAttribute("id"); let 重渲染配置 = await 获取重渲染配置(sql, id); if ( 重渲染配置 && 重渲染配置.sql替换 && 重渲染配置.sql替换 instanceof Function ) { sql = await 重渲染配置.sql替换(sql, id); } if (sql && 重渲染配置) { let 查询结果 = await 获取查询结果(sql); if (查询结果 && 查询结果[0]) { if (校验查询结果为嵌入(查询结果)) { return; } let 表格 = document.createElement("table"); 表格.setAttribute("contenteditable", false); 表格.setAttribute("spellcheck", false); 表格.innerHTML = "<colgroup></colgroup>"; for (let i = 0; i < Object.getOwnPropertyNames(查询结果[0]).length; i++) { 表格.querySelector("colgroup").innerHTML += "<col></col>"; } let 表头 = await 生成表头(查询结果[0], 重渲染配置, sql, id); let 表身 = await 生成表身(查询结果, 重渲染配置, sql, id); 表格.appendChild(表头); 表格.appendChild(表身); 刷新表格(嵌入块元素, 表格); } } } function 获取重渲染配置(sql, id) { let 重渲染配置 = 重渲染配置表.find((item) => { return item.判定函数(sql, id); }); return 重渲染配置; } function 校验查询结果为嵌入(查询结果) { let 字段名列表 = Object.getOwnPropertyNames(查询结果[0]); return ( JSON.stringify(字段名列表) == `["alias","box","content","created","fcontent","hash","hpath","ial","id","length","markdown","memo","name","parent_id","path","root_id","sort","subtype","tag","type","updated"]` ); } async function 刷新表格(嵌入块元素, 表格) { let 插入容器 = 嵌入块元素.querySelector( ".ft__smaller.ft__secondary.b3-form__space--small" ); if (!插入容器) { return; } if (!插入容器.shadowRoot) { 插入容器.attachShadow({ mode: "open" }); } 插入容器.shadowRoot.innerHTML = ""; 插入容器.shadowRoot.innerHTML += ` <link rel="stylesheet" type="text/css" href="/snippets/embedTable/table.css"> </link> `; 插入容器.shadowRoot.appendChild(表格); } async function 获取查询结果(sql) { let data = await fetch("/api/query/sql", { method: "post", body: JSON.stringify({ stmt: sql, }), }); return (await data.json()).data; } async function 生成表头(结果条目, 重渲染配置, sql, id) { let 字段名列表 = Object.getOwnPropertyNames(结果条目); if ( 重渲染配置 && 重渲染配置.字段过滤 && 重渲染配置.字段过滤 instanceof Function ) { 字段名列表 = await 重渲染配置.字段过滤(字段名列表, sql, id); } console.log(字段名列表.length); let 表头元素 = document.createElement("thead"); 表头元素.innerHTML = "<thead><tr></tr></thead>"; for await (let 字段名 of 字段名列表) { if ( 重渲染配置 && 重渲染配置.表头替换 && 重渲染配置.表头替换 instanceof Function ) { 字段名 = await 重渲染配置.表头替换(字段名, sql, id); } 表头元素.querySelector("tr").innerHTML += `<th>${字段名}</th>`; } return 表头元素; } async function 生成表身(查询结果, 重渲染配置, sql, id) { let 表身元素 = document.createElement("tbody"); let 字段名列表 = Object.getOwnPropertyNames(查询结果[0]); if ( 重渲染配置 && 重渲染配置.字段过滤 && 重渲染配置.字段过滤 instanceof Function ) { 字段名列表 = 重渲染配置.字段过滤(字段名列表, sql, id); } for await (let 结果条目 of 查询结果) { 表身元素.appendChild( await 生成行(结果条目, 字段名列表, 重渲染配置, sql, id) ); } return 表身元素; } async function 生成行(结果条目, 字段名列表, 重渲染配置, sql, id) { console.log(字段名列表); let 行元素 = document.createElement("tr"); for await (let 属性名 of 字段名列表) { let 属性值 = 结果条目[属性名]; if ( 重渲染配置 && 重渲染配置.表身替换 && 重渲染配置.表身替换 instanceof Function ) { 属性值 = 重渲染配置.表身替换(属性值, 结果条目, sql, id); } console.log(属性值); 行元素.innerHTML += `<td>${属性值}</td>`; } return 行元素; }

model.js 里面是一个很简单的 websocket 监听,就不放出来了,反正有文件,可以自己看一下。

好了文件包在这里,没有依赖就是一个单纯的代码片段,有能力的筒子还可以分享自己写的 replace.js 玩。

链接:https://pan.baidu.com/s/1lNy8oqviEJIg-3pVVbRXmg?pwd=i477
提取码:i477
--来自百度网盘超级会员 V5 的分享

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    25294 引用 • 104403 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • foolishman83

    下载的文件夹放在哪里才能生效,是不是属于挂件?

推荐标签 标签

  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 246 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 650 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 1 关注
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 3 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 16 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    21 引用 • 31 回帖
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    199 引用 • 542 回帖
  • 音乐

    你听到信仰的声音了么?

    62 引用 • 512 回帖
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 2 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    289 引用 • 4492 回帖 • 655 关注
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    117 引用 • 99 回帖 • 206 关注
  • 倾城之链
    23 引用 • 66 回帖 • 165 关注
  • jsDelivr

    jsDelivr 是一个开源的 CDN 服务,可为 npm 包、GitHub 仓库提供免费、快速并且可靠的全球 CDN 加速服务。

    5 引用 • 31 回帖 • 111 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 294 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    188 引用 • 318 回帖 • 254 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    211 引用 • 358 回帖 • 1 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    84 引用 • 324 回帖 • 1 关注
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖 • 4 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    116 引用 • 54 回帖
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 65 关注
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 734 关注
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 593 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 435 关注