【分享】html 内容块 +quicker 实现对嵌入块分页查询

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

因为嵌入块一般特别长,想分页进行浏览就不用一次性看完了。

结合思源的 html 块,块属性实现对嵌入块的分页查询。代码很烂,不喜轻轻喷。

用法

  1. 复制 html 代码到 html 块中,并修改 custom_id 为唯一标识。建议这个 id 使用 html 块 id。(html 代码去文末复制)
  2. 配置 html 块的属性。
    1. qrkid 表示 嵌入块 id
    2. quickeruri 指 这个动作的 uri 地址。quicker 动作
    3. sql :结尾不要用分号,不要用 limit ,不要用 || 拼接字符串 (嵌入块好像不支持)。
  3. 在 quicker 中配置 siyuan token。

注意 :目前还不完善。

  1. 建议同时只打开一个使用 html 块对嵌入块进行分页查询的文档。(js 写得很烂,打开多了可能 dom 会获取)
  2. 要 html 块里面的 custom_id 每个 html 中要使用不一样的。(推荐使用 html 块 id,这样就都不同了)
  3. 查询的 sql 请注意,不要查询到自身或者同样使用 html 块进行分页查询的文档,以防套娃,导致程序崩溃。

AEM9KCAR2PA81RBKEH.gif

html 代码如下:

<html>
<head>
    <style>
        #page_nav{width:100%;height:50px;display: flex; justify-content: center;}
        .page_btn{width:60px;display: inline-block; text-align: center;height: 50px;line-height: 50px;}
        #page_nav a{color: #8ab4f8;  cursor: pointer;}
        #pageNum{width:50px;}
    </style>
</head>
<body>
    <div id="page_nav">
        <form onload="formLoad()"  readonly></form>
        <a id="first" class="page_btn" href="javascript:first()">首页</a>
        <a id="pre" class="page_btn"  href="javascript:pre()">上一页</a>
       <input id="pageNum" name="pageNum" value="0" readonly placeholder="第几页"/>
        <a id="next" class="page_btn"  href="javascript:next()">下一页</a>
        <p>查询条数
            <select id="querycount" onchange="changeCount()">
                <option value="1">1</option>
                <option value="2">2</option>
                <option value="3">3</option>
                <option value="4">4</option>
                <option value="5" selected="selected">5</option>
                <option value="6">6</option>
                <option value="7">7</option>
                <option value="8">8</option>
                <option value="9">9</option>
                <option value="10">10</option>
                <option value="20">20</option>
                <option value="25">25</option>
                <option value="30">30</option>
                <option value="50">50</option>          
            </select>
        </p>  
    </div>
</body>
<script>
{
  
    const customID = '这个id为用户自己设置,用来唯一标识这个块的,建议使用html块id';//如:20220507204221-l9rthtz
    let Me = This(customID);
    console.log(Me);

  
  
    // 初始化,自动加载 pageNum 和pageCount
    init();

    function init(){
        var embeddedBlockId =  Me.block.getAttribute('custom-qrkid');
        if(!embeddedBlockId){
            alert("需要在HTML块的属性中配置 :qrkid ! ")
            return;
        }

       var pageNum =  document.querySelector(`div[data-node-id="${embeddedBlockId}"`).getAttribute('custom-pagenum');
       var querycount = document.querySelector(`div[data-node-id="${embeddedBlockId}"`).getAttribute('custom-querycount');
        if(!pageNum || !querycount){
            return;
        }
        Me.shadowRoot.querySelector("#pageNum").value = parseInt(pageNum); 
        Me.shadowRoot.querySelector("#querycount").value = parseInt(querycount);
    }

    /**
     * HTML 块中的脚本获取当前块相关信息
     * @params {string} customID 内部定义的 ID
     * @returns {string} id 当前 HTML 块 ID
     * @returns {HTMLElement} block 当前 HTML 块
     * @returns {HTMLElement} shadowRoot 当前 HTML 块 shadowRoot
     */
    function This(customID) {
        let protyle = document.querySelector(`protyle-html[data-content*="${customID}"]`);
        if (protyle) {
            let block = protyle.parentElement.parentElement;
            return {
                id: block.dataset.nodeId,
                block: block,
                shadowRoot: protyle.shadowRoot,
            };
        } else return null;
    }
  
    function changeCount(){
        first()
    }
    function first(){
        Me.shadowRoot.querySelector("#pageNum").value = 0; 
        refreshEmbeddedBlock();
    }
    function pre(){
        var pageNum = parseInt(Me.shadowRoot.querySelector("#pageNum").value || 0);
        if(pageNum <= 0){
            return;
        }
        Me.shadowRoot.querySelector("#pageNum").value = pageNum -1;
        refreshEmbeddedBlock();
    }
    function next(){
        var pageNum = parseInt(Me.shadowRoot.querySelector("#pageNum").value || 0);
        Me.shadowRoot.querySelector("#pageNum").value = pageNum + 1;
        refreshEmbeddedBlock();
    }
  
    function refreshEmbeddedBlock() {
        var embeddedBlockId =  Me.block.getAttribute('custom-qrkid');
        var sql =  Me.block.getAttribute('custom-sql');
        var quickeruri =  Me.block.getAttribute('custom-quickeruri');
    
        if(!embeddedBlockId || !sql || !quickeruri){
            console.log("embeddedBlockId:" + embeddedBlockId)
            console.log("sql:" + sql)
            console.log("quickeruri:" + quickeruri)
        
            alert("需要在HTML块的属性中配置 :qrkid , sql , quickeruri 这几个属性!! ")
        }
   
        var pageNum = parseInt(Me.shadowRoot.querySelector("#pageNum").value || 0);
        var querycount =  parseInt(Me.shadowRoot.querySelector("#querycount").value || 0);
        if(querycount <= 0){
            alert("请重新设置查询条数!")
        }

        sql = `${sql} limit ${pageNum*querycount} , ${querycount}`
        // alert(`embeddedBlockId:${embeddedBlockId}\n pageNum:${pageNum}\n querycount:${querycount}\n `)
        var jsonStr = JSON.stringify({qrkid:embeddedBlockId,sql:sql,pagenum:pageNum,querycount:querycount});
        // console.log(jsonStr)
        // var full_quickeruri = `${quickeruri}?qrkid=${embeddedBlockId}&sql=${sql}`;
        var full_quickeruri = `${quickeruri}?${jsonStr}`;
        console.log(full_quickeruri);
        location.href =full_quickeruri;
    }
}

</script>
</html>
  • 思源笔记

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

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

    22026 引用 • 87850 回帖 • 3 关注

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
kobi
❤️❤️快速整理笔记,最重要的功能应当是什么呢❗❓

推荐标签 标签

  • 996
    13 引用 • 200 回帖 • 1 关注
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    26 引用 • 222 回帖 • 165 关注
  • Solidity

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

    3 引用 • 18 回帖 • 384 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 632 关注
  • uTools

    uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。

    6 引用 • 14 回帖 • 2 关注
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 672 关注
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 65 回帖 • 452 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 232 回帖 • 4 关注
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 338 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 29 关注
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    122 引用 • 73 回帖
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    677 引用 • 535 回帖
  • danl
    129 关注
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 1 关注
  • 黑曜石

    黑曜石是一款强大的知识库工具,支持本地 Markdown 文件编辑,支持双向链接和关系图。

    A second brain, for you, forever.

    14 引用 • 106 回帖 • 1 关注
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 461 关注
  • ActiveMQ

    ActiveMQ 是 Apache 旗下的一款开源消息总线系统,它完整实现了 JMS 规范,是一个企业级的消息中间件。

    19 引用 • 13 回帖 • 668 关注
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 561 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    46 引用 • 25 回帖
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 97 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    152 引用 • 3781 回帖
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 181 关注
  • Bug

    Bug 本意是指臭虫、缺陷、损坏、犯贫、窃听器、小虫等。现在人们把在程序中一些缺陷或问题统称为 bug(漏洞)。

    75 引用 • 1737 回帖 • 1 关注
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    105 引用 • 127 回帖 • 395 关注
  • ZeroNet

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

    1 引用 • 21 回帖 • 637 关注
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 126 关注
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    490 引用 • 916 回帖