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

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

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

结合思源的 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>
  • 思源笔记

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

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

    22391 引用 • 89649 回帖

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    286 引用 • 248 回帖 • 62 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 474 关注
  • uTools

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

    6 引用 • 14 回帖 • 1 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    107 引用 • 153 回帖 • 3 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    28 引用 • 108 回帖 • 1 关注
  • Facebook

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

    4 引用 • 15 回帖 • 453 关注
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    568 引用 • 3532 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    334 引用 • 323 回帖 • 2 关注
  • Sublime

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

    10 引用 • 5 回帖 • 1 关注
  • Oracle

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

    105 引用 • 127 回帖 • 381 关注
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    75 引用 • 258 回帖 • 619 关注
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 2 关注
  • TGIF

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

    287 引用 • 4484 回帖 • 669 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 55 关注
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    407 引用 • 1246 回帖 • 581 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    342 引用 • 708 回帖
  • Caddy

    Caddy 是一款默认自动启用 HTTPS 的 HTTP/2 Web 服务器。

    12 引用 • 54 回帖 • 165 关注
  • danl
    133 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 384 关注
  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 536 关注
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 16 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 609 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    91 引用 • 384 回帖
  • Spark

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

    74 引用 • 46 回帖 • 553 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 471 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    62 引用 • 289 回帖