因为嵌入块一般特别长,想分页进行浏览就不用一次性看完了。
结合思源的 html 块,块属性实现对嵌入块的分页查询。代码很烂,不喜轻轻喷。
用法 :
- 复制 html 代码到 html 块中,并修改 custom_id 为唯一标识。建议这个 id 使用 html 块 id。(html 代码去文末复制)
- 配置 html 块的属性。
- qrkid 表示 嵌入块 id
- quickeruri 指 这个动作的 uri 地址。quicker 动作
- sql :结尾不要用分号,不要用 limit ,不要用 || 拼接字符串 (嵌入块好像不支持)。
- 在 quicker 中配置 siyuan token。
注意 :目前还不完善。
- 建议同时只打开一个使用 html 块对嵌入块进行分页查询的文档。(js 写得很烂,打开多了可能 dom 会获取)
- 要 html 块里面的 custom_id 每个 html 中要使用不一样的。(推荐使用 html 块 id,这样就都不同了)
- 查询的 sql 请注意,不要查询到自身或者同样使用 html 块进行分页查询的文档,以防套娃,导致程序崩溃。
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>
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于