随手记:树结构翻页和定位指定数据逻辑

业务背景:

树形组件展示数据,数据包含过去数据,现在数据,未来数据,用户在首次进入页面时,展示的是当天的数据,如果当天没有数据,则显示最近一条的过去数据。数据按照时间越长数据会越来越多,过去未来现在都可能有数据或者没有数据。
 

和后端约定数据返回结构:
约定一次性返回多少条数据作为首次进入的展示,今天的数据给一个标记,如果今天没有数据,则查询今天之前的一条数据作为标记返回。标记的只有一个。
 

前端思维点:
定位当前:
首次获取数据时,将数据赋值树形结构接收,给标记的数据设为唯一的id值,获取id元素距离最外层 元素的距离,将滚动条距离顶部的距离等于id元素距离最外层 元素的距离,可以实现首次进入定位到当前最近的数据作为展示。
向上翻页:当滚动条距离顶部的距离等于0的,做向上翻页,给后端传原返回数据第一个日期
向下翻页:当判断滚动条触底时,做向下翻页,给后端传原返回数据最后一个日期

      <div class="custom-tree-container font12"><div class="block tree-data" id="treeId"><el-tree:data="treedData"node-key="id"default-expand-all:expand-on-click-node="false"><span slot-scope="{ node, data }" :id="data.labelId"><i v-if="data.children"></i><span class="circle" v-else></span><span class="text"  @click="treeItem(node, data)">{{ node.label}}</span></span></el-tree></div></div>

    // 获取标记今天的元素距离父元素的距离getOffSet() {this.treeEL = document.querySelector('.tree-data');this.todayEL = document.querySelector('#today');console.log('标记的数据距离元素的高度',this.todayEL.offsetTop)this.treeEL.addEventListener('scroll', this.getScrollTop,false)},// 监听鼠标距离顶部距离getScrollTop() {// console.log('监听鼠标距离顶部距离',this.treeEL.scrollTop)const clientHeight = this.treeEL.clientHeight;const scrollTop = this.treeEL.scrollTop;const scrollHeight = this.treeEL.scrollHeight;if (clientHeight + scrollTop === scrollHeight) {console.log('竖向滚动条已经滚动到底部,需要向下翻页')}if (scrollTop === 0) {console.log('竖向滚动条已经滚动到顶部,需要向上翻页')}},

目前就前端暂时画完了页面,后端还在接口设计,后续联调

待更新.....


 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/651009.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《QT实用小工具·三十五》基于PathView,Qt/QML做的一个可以无限滚动的日历控件

1、概述 源码放在文章末尾 改项目实现了基于PathView&#xff0c;Qt/QML做的一个可以无限滚动的日历控件&#xff0c;下面是demo演示&#xff1a; 项目部分代码如下所示&#xff1a; import QtQuick 2.7 import QtQuick.Controls 1.4 import QtQuick.Controls.Styles 1.4Bu…

基于JavaWEB的学生考勤管理系统(含论文)

本系统是用Java语言写的&#xff0c;基于JavaWEB的学生考勤管理系统 主要有三大模块&#xff0c;学生&#xff0c;教师和管理员模块&#xff0c;功能如下&#xff1a; 学生模块 教师模块&#xff1a; 管理员模块

python-opencv实现最近邻插值和双线性插值对图片上采样

使用背景 当我们需要把图像进行放大或者缩小的时候&#xff0c;第一反应是使用resize()实现。很多情况下&#xff0c;我们会调用最近邻插值和双线性插值去放大图片&#xff0c;当然要说没有分辨率的损失那是不可能的&#xff0c;只能说在放大图片的过程中尽可能增加了图片的分…

SQL优化——全自动SQL审核

文章目录 1、抓出外键没创建索引的表2、抓出需要收集直方图的列3、抓出必须创建索引的列4、抓出SELECT * 的SQL5、抓出有标量子查询的SQL6、抓出带有自定义函数的SQL7、抓出表被多次反复调用SQL8、抓出走了FILTER的SQL9、抓出返回行数较多的嵌套循环SQL10、抓出NL被驱动表走了全…

RabbitMQ中的交换机类型

交换机类型 可以看到&#xff0c;在订阅模型中&#xff0c;多了一个exchange角色&#xff0c;而且过程略有变化&#xff1a; Publisher&#xff1a;生产者&#xff0c;不再发送消息到队列中&#xff0c;而是发给交换机 Exchange&#xff1a;交换机&#xff0c;一方面&#xff…

防盗链在nginx中如何配置,简单演示403forbidden的效果

一、使用场景&#xff1a; 资源被其他网站无端盗用 服务器压力无端增加 二、实现方法 1.valid_referers指令可以检测被访问资源从哪个地址来 2.通过referer头字段判断 3.若为空&#xff0c;报403错误 nginx的准备工作&#xff1a; 可以看 虚拟机中使用LNMP模拟跨域并结合…

盲人使用公共设施:科技助力无障碍出行与智能识别

在我们的日常生活中&#xff0c;公共设施扮演着不可或缺的角色&#xff0c;它们为人们提供了便利的服务&#xff0c;构建起和谐、高效的社会环境。然而&#xff0c;对于视障人士而言&#xff0c;尽管公共设施设计之初便考虑到通用性和包容性&#xff0c;实际使用过程中仍难免遭…

算法——BFS算法

1. 什么是BFS算法 BFS&#xff08;广度优先搜索&#xff0c;Breadth-First Search&#xff09;算法是一种用于图和树等数据结构中进行搜索的基本算法。它从指定的起始节点开始&#xff0c;逐层地向外扩展搜索&#xff0c;直到找到目标节点或遍历完整个图。 BFS算法的基本思想是…

一篇文章带您了解java的API-String

1.为什么要学习字符串的处理&#xff1f; 在开发中需要大量的使用字符串&#xff0c;比如登录注册&#xff0c;留言之类的。 根据java的api文档中可知&#xff0c;String类表示字符串&#xff0c;java中的所有字符串都实现为此类的实例。 字符串是不变的&#xff0c;他们的值…

【linux】匿名管道|进程池

1.进程为什么要通信&#xff1f; 进程也是需要某种协同的&#xff0c;所以如何协同的前提条件(通信) 通信数据的类别&#xff1a; 1.通知就绪的 2.单纯的数据 3.控制相关的信息 2.进程如何通信&#xff1f; 进程间通信&#xff0c;成本会高一点 进程间通信的前提&#xff0c;先…

全志ARM-网络链接

命令扫描周围的WIFI热点 nmcli dev wifi 命令接入网络 nmcli dev wifi connect &#xff08;WiFi名&#xff0c;不要有空格&#xff09;password (WiFi密码) 查看IP地址 ip addr show wlan0或ifconfig 出现successfully就连接成功了

C++:const成员和取地址操作符

目录 一、const成员 二、取地址及const取地址操作符重载 一、const成员 将const修饰的“成员函数”称之为const成员函数&#xff0c;const修饰类成员函数&#xff0c;实际修饰该成员函数 隐含的this指针&#xff0c;表明在该成员函数中不能对类的任何成员进行修改。 注&…