CN113642292B - 一种树形列表的实现方法、系统、设备及存储介质 - Google Patents
一种树形列表的实现方法、系统、设备及存储介质 Download PDFInfo
- Publication number
- CN113642292B CN113642292B CN202110794479.0A CN202110794479A CN113642292B CN 113642292 B CN113642292 B CN 113642292B CN 202110794479 A CN202110794479 A CN 202110794479A CN 113642292 B CN113642292 B CN 113642292B
- Authority
- CN
- China
- Prior art keywords
- list
- node
- tree
- child nodes
- rolling
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/12—Use of codes for handling textual entities
- G06F40/14—Tree-structured documents
- G06F40/143—Markup, e.g. Standard Generalized Markup Language [SGML] or Document Type Definition [DTD]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/951—Indexing; Web crawling techniques
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/957—Browsing optimisation, e.g. caching or content distillation
- G06F16/9577—Optimising the visualization of content, e.g. distillation of HTML documents
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Health & Medical Sciences (AREA)
- Artificial Intelligence (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- General Health & Medical Sciences (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明公开了一种树形列表的实现方法、系统、设备及存储介质,涉及计算机树形控件配置技术领域。所述方法包括:利用标签属性建立多层父子结构,得到原始树形结构;将原始树形结构转化为平铺的单层数组结构;将单层数组结构转化成数组标签,得到平铺树形列表;根据平铺树形列表,创建容器节点、滚动盒子和列表盒子,并完成树形列表滚动加载设计,得到滚动列表;在滚动列表的列表标签上注册点击事件,获取节点类型;根据节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表。本发明能够减少大数据量的情况下列表中的标签被大量创建导致的性能变差的问题。
Description
技术领域
本发明涉及计算机树形控件配置技术领域,尤其涉及一种树形列表的实现方法、系统、设备及存储介质。
背景技术
web客户端的树形列表在信息管理系统中被广泛的应用,其对数据拥有良好的分类能力,能让用户非常准确的定位到数据的位置,如应用在人员管理中,用户可以先根据职位分类进行查找,再通过该职位下再去搜索相关人员搜索效率会有显著的提高。随着企业业务数据的日益增多,对树形列表使用的依赖,如何优化树形列表的使用及显示性能是十分重要的。而web技术依赖于浏览器渲染的性能,操作卡顿等性能问题,如何高效的展示大数据量的树形列表成为了亟待改善的技术问题。
现代浏览器对树形列表的支持,依赖于html文档使用XML标签的特性,列表节点的子节点采用XML标签的方式包裹在里面,再使用层叠样式表(Cascading Style Sheets,CSS)实现展开收起子节点,但如果节点的父子结构复杂且数量多,难以去优化性能,一些性能优化的方法如节点展开后再创建子节点,但如果子节点数量过多,会导致节点创建过慢导致浏览器的卡顿,而在创建大量的子节点后再使用收起子节点的操作时,需要销毁大量标签,也会造成浏览器的卡顿。此外,如果父子节点的层级过深,会对浏览器解析html文档时也会造成性能损耗,在大数据量的情况下,无法很好解决性能问题。
发明内容
本发明目的在于,提供一种树形列表的实现方法、系统、设备及存储介质,以减少大数据量的情况下列表中的标签被大量创建导致的性能变差的问题。
为实现上述目的,本发明实施例提供一种树形列表的实现方法,包括:
利用标签属性建立多层父子结构,得到原始树形结构;
将所述原始树形结构转化为平铺的单层数组结构;
将所述单层数组结构转化成数组标签,得到平铺树形列表;其中,所述数组标签能够通过深度属性区分显示样式;
根据所述平铺树形列表,创建容器节点、滚动盒子和列表盒子;
根据所述容器节点、所述滚动盒子和所述列表盒子,完成树形列表滚动加载设计,得到滚动列表;
在所述滚动列表的列表标签上注册点击事件,获取节点类型;
根据所述节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表。
优选地,所述将所述单层数组结构转化成数组标签,得到平铺树形列表,包括:
将单层数组结构导入预设数据逻辑,遍历参数后形成递归函数,得到平铺树形列表。
优选地,所述根据所述容器节点、所述滚动盒子和所述列表盒子,完成树形列表滚动加载设计,得到滚动列表,包括:
为所述容器节点设置滚动条监听事件;其中,所述滚动条监听事件用于在滚动条滚动时获取滚动条的滚动高度;
根据树形列表预设的长度值设置所述滚动盒子和所述列表盒子的高度和宽度;
根据所述滚动盒子和所述列表盒子的高度和宽度,获得待渲染列表的节点索引集合;
根据所述节点索引集合,在所述平铺树形列表中获取节点,创建节点标签,得到滚动列表。
优选地,所述根据所述节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表,包括:
当所述子节点为收起状态时,取出当前节点中的所有子节点,依次向父节点的索引位置插入、修改并更新子节点显示状态并重新渲染树形列表,达到子节点展开效果;
当所述子节点为展开状态时,取出当前节点中子节点的长度,依次向父节点的索引位置后删除子节点长度数量的,若子节点内还有子节点,则根据其子节点的数量递归删除,修改并更新子节点显示状态并重新渲染树形列表,达到子节点收起效果。
本发明实施例还提供一种树形列表的实现系统,包括:
原始结构构造模块,用于通过标签属性建立多层父子结构,得到原始树形结构;
平铺模块,用于将所述原始树形结构转化为平铺的单层数组结构;
打标模块,用于将所述单层数组结构转化成数组标签,得到平铺树形列表;其中,所述数组标签能够通过深度属性区分显示样式;
节点构建模块,用于根据所述平铺树形列表,创建容器节点、滚动盒子和列表盒子;
滚动设计模块,用于根据所述容器节点、所述滚动盒子和所述列表盒子,完成树形列表滚动加载设计,得到滚动列表;
节点分析模块,用于在所述滚动列表的列表标签上注册点击事件,获取节点类型;
渲染模块,用于根据所述节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表。
优选地,所述打标模块还用于将单层数组结构导入预设数据逻辑,遍历参数后形成递归函数,得到平铺树形列表。
优选地,所述滚动设计模块包括:
监听单元,用于为所述容器节点设置滚动条监听事件;其中,所述滚动条监听事件用于在滚动条滚动时获取滚动条的滚动高度;
数据限定单元,用于根据树形列表预设的长度值设置所述滚动盒子和所述列表盒子的高度和宽度;
节点索引单元,用于根据所述滚动盒子和所述列表盒子的高度和宽度,获得待渲染列表的节点索引集合;
节点获取单元,用于根据所述节点索引集合,在所述平铺树形列表中获取节点,创建节点标签,得到滚动列表。
优选地,所述渲染模块包括:
展开渲染单元,用于在所述子节点为收起状态时,取出当前节点中的所有子节点,依次向父节点的索引位置插入、修改并更新子节点显示状态并重新渲染树形列表,达到子节点展开效果;
收起渲染单元,用于在所述子节点为展开状态时,取出当前节点中子节点的长度,依次向父节点的索引位置后删除子节点长度数量的,若子节点内还有子节点,则根据其子节点的数量递归删除,修改并更新子节点显示状态并重新渲染树形列表,达到子节点收起效果。
本发明实施例还提供一种计算机终端设备,包括一个或多个处理器和存储器。存储器与所述处理器耦接,用于存储一个或多个程序;当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如上述任一实施例所述的树形列表的实现方法。
本发明实施例还提供一种计算机可读存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现如上述任一实施例所述的树形列表的实现方法。
与现有技术相比,本发明具有以下有益效果:
本发明公开的树形列表的实现方法,包括:利用标签属性建立多层父子结构,得到原始树形结构;将所述原始树形结构转化为平铺的单层数组结构;将所述单层数组结构转化成数组标签,得到平铺树形列表;其中,所述数组标签能够通过深度属性区分显示样式;根据所述平铺树形列表,创建容器节点、滚动盒子和列表盒子;根据所述容器节点、所述滚动盒子和所述列表盒子,完成树形列表滚动加载设计,得到滚动列表;在所述滚动列表的列表标签上注册点击事件,获取节点类型;根据所述节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表。本发明能够减少大数据量的情况下列表中的标签被大量创建导致的性能变差的问题。
附图说明
为了更清楚地说明本发明的技术方案,下面将对实施方式中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施方式,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明某一实施例提供的树形列表的实现方法的流程示意图;
图2是本发明另一实施例提供的树形列表的实现方法的流程示意图;
图3是本发明又一实施例提供的树形列表的实现方法的流程示意图;
图4是本发明某一实施例提供的树形列表的实现系统的结构示意图;
图5是本发明某一实施例提供的计算机终端设备的结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
应当理解,文中所使用的步骤编号仅是为了方便描述,不作为对步骤执行先后顺序的限定。
应当理解,在本发明说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本发明。如在本发明说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
术语“包括”和“包含”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
请参阅图1,图1为本发明某一实施例提供的树形列表的实现方法的流程示意图。在本实施例中,树形列表的实现方法,包括以下步骤:
S110,利用标签属性建立多层父子结构,得到原始树形结构;
S120,将所述原始树形结构转化为平铺的单层数组结构;
S130,将所述单层数组结构转化成数组标签,得到平铺树形列表;其中,所述数组标签能够通过深度属性区分显示样式;
S140,根据所述平铺树形列表,创建容器节点、滚动盒子和列表盒子;
S150,根据所述容器节点、所述滚动盒子和所述列表盒子,完成树形列表滚动加载设计,得到滚动列表;
S160,在所述滚动列表的列表标签上注册点击事件,获取节点类型;
S170,根据所述节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表。
由于现有的树形列表依赖于HTML XML文档父子标签的结构,在大数据量节点的父子结构复杂且数量多,性能较差且难以优化,大量的节点创建导致浏览器持续占用大量内存,导致渲染性能下降,页面卡顿,在性能较差的设备中还会引发web页面崩溃的问题。为了提升树形列表在大数据量的情况下使用时的页面性能,包括展示、展开节点、收起节点等性能。本某一实施例,首先,使用html和css技术,设计一个可以不依赖XML父子标志特性的树形列表;然后,使用javascript技术,设计一种让树形列表滚动时只渲染当前滚动位置显示区域内的标签,减少大数据量时html标签被大量创建导致的性能问题;最后,使用javascript技术,实现这种树形列表展开和收起子节点的方法。
在本发明实施例中,步骤S130,还包括:将单层数组结构导入预设数据逻辑,遍历参数后形成递归函数,得到平铺树形列表。
请参阅图2,图2为本发明另一实施例提供的树形列表的实现方法的流程示意图。在本发明实施例中,步骤S150,具体包括以下步骤:
S151,为所述容器节点设置滚动条监听事件;其中,所述滚动条监听事件用于在滚动条滚动时获取滚动条的滚动高度;
S152,根据树形列表预设的长度值设置所述滚动盒子和所述列表盒子的高度和宽度;
S153,根据所述滚动盒子和所述列表盒子的高度和宽度,获得待渲染列表的节点索引集合;
S154,根据所述节点索引集合,在所述平铺树形列表中获取节点,创建节点标签,得到滚动列表。
请参阅图3,图3为本发明又一实施例提供的树形列表的实现方法的流程示意图。在本发明实施例中,步骤S170,具体包括以下步骤:
S171,当所述子节点为收起状态时,取出当前节点中的所有子节点,依次向父节点的索引位置插入、修改并更新子节点显示状态并重新渲染树形列表,达到子节点展开效果;
S172,当所述子节点为展开状态时,取出当前节点中子节点的长度,依次向父节点的索引位置后删除子节点长度数量的,若子节点内还有子节点,则根据其子节点的数量递归删除,修改并更新子节点显示状态并重新渲染树形列表,达到子节点收起效果。
在某一具体实施例中,为了实现利用标签属性区分而不再依靠XML标签嵌套,将所有节点不管树形列表层级在哪一个层的节点都放在同一层。例如,标签类属性class(类名)定义值’deep-1’代表第一层、’deep-2’代表第二层...,所有节点都在同一层,这样可以解决多层父子结构导致html占用过多内存导致页面渲染性能的下降。
在某一具体实施例中,将所述原始树形结构转化为平铺的单层数组结构,设原始数据为json数据:
首先,定义一个数组arr,然后定义一个遍历函数fn(data),把原始数据代入fn的参数data执行,最后定义fn逻辑,遍历原始数据,把每次遍历目标插入数组arr,果遍历目标有子节点,则把子节点代入fn的参数data执行,形成一个递归。
上述步骤执行完成后,获得平铺后的数据arr:
arr=[
{
‘名称’:’1’,
‘深度’:’1’
},
{
‘名称’:’1-1’,
‘深度’:’2’
},
{
‘名称’:’1-2’,
‘深度’:’2’
},
{
‘名称’:’2’,
‘深度’:’1’
},
{
‘名称’:’2-1’,
‘深度’:’2’
},
{
‘名称’:’2-2’,
‘深度’:’2’
}
]
再遍历数组arr转化成标签得到:
<div class='deep-1'>1</div>
<div class='deep-2'>1-1</div>
<div class='deep-2'>1-2</div>
<div class='deep-1'>2</div>
<div class='deep-2'>2-1</div>
<div class='deep-2'>2-2</div>
该标签可以通过其深度属性区分显示样式,增加以下样式
给类有deep-2的标签增加左边距20px
deep-2{
Padding-left(左边距):20px
}
最后得到平铺树形列表实现的树形列表。
在某一具体实施例中,使用javascript技术,设计一种让树形列表滚动时只渲染当前滚动位置显示区域内的标签,平铺树形列表能够解决现有技术树形列表标签嵌套过多的问题,但大数据量的列表渲染会创建大量的节点,会消耗大量的内存导致浏览器卡顿或崩溃。这里再为平铺的数组列表使用虚拟滚动技术,只渲染浏览器可视区域内的树形列表节点,当列表滚动时触发事件修改可视区域内部的节点,其实现步骤如下:设由1创建长度为1000的平铺树形列表的数据结构:
arr=[
{
‘名称’:’1’,
‘深度’:’1’
},
{
‘名称’:’1-1’,
‘深度’:’2’
},
{
‘名称’:’1-2’,
‘深度’:’2’
},
{
‘名称’:’2’,
‘深度’:’1’
},
{
‘名称’:’2-1’,
‘深度’:’2’
},
{
‘名称’:’2-2’,
‘深度’:’2’
}
...(省略)
]
基于此,创建容器节点,滚动盒子(scroll-content)及列表盒子(list-content):
<div id='scroll-content'>
<div id='list-content'>
<div>
设列表每行行高为50,滚动盒子高度为300;设列表盒子的高度为1000(树形列表节点总数)*50(列表每行行高);为容器节点设置滚动条监听事件,当滚动条滚动时获取当前滚动条的滚动高度;初始化及列表滚动时,计算出当前列表要渲染的第一个节点的索引值:index(索引值)=(滚动高度-滚动盒子高度)/行高,其值为负数则取0;根据列表可视区域的数量:len(可视区域的数量)=盒子高度/每行行高;得到要渲染列表的节点索引集合:
[index,index+1,index+2,...,index+len];通过节点索引在arr(平铺树形列表)中获取节点,创建标签;清空列表盒子(list-content)原有的子标签,把新创建的标签插入其中;完成树形列表滚动加载设计。通过此设计,每次滚动只需要渲染10个左右的节点,可以大大节约大数据渲染下的内存。
在某一具体实施例中,使用javascript技术,为了实现不需要依赖HTML XML父子标签的特性,也能实现树形列表展开和收起子节点的方法,其步骤如下:往树形列表标签上注册点击事件;点击事件获取该节点的节点类型,如果其有子节点再继续执行逻辑;如果子节点是收起状态,取出该节点的所有子节点,依次往父节点的索引位置插入,修改并更新子节点显示状态并重新渲染树形列表,达到子节点展开效果;如果子节点是展开状态,取出该节点的子节点长度,依次往父节点的索引位置后删除子节点长度数量的,若子节点内还有子节点,则根据其子节点的数量递归删除,修改并更新子节点显示状态并重新渲染树形列表,达到子节点收起效果。
请参阅图4,图4为本发明某一实施例提供的树形列表的实现系统的结构示意图。本实施例提供的树形列表的实现系统,包括:
原始结构构造模块210,用于通过标签属性建立多层父子结构,得到原始树形结构;
平铺模块220,用于将所述原始树形结构转化为平铺的单层数组结构;
打标模块230,用于将所述单层数组结构转化成数组标签,得到平铺树形列表;其中,所述数组标签能够通过深度属性区分显示样式;
节点构建模块240,用于根据所述平铺树形列表,创建容器节点、滚动盒子和列表盒子;
滚动设计模块250,用于根据所述容器节点、所述滚动盒子和所述列表盒子,完成树形列表滚动加载设计,得到滚动列表;
节点分析模块260,用于在所述滚动列表的列表标签上注册点击事件,获取节点类型;
渲染模块270,用于根据所述节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表。
在本发明实施例中,所述打标模块230还用于将单层数组结构导入预设数据逻辑,遍历参数后形成递归函数,得到平铺树形列表。
在本发明实施例中,所述滚动设计模块250包括:
监听单元,用于为所述容器节点设置滚动条监听事件;其中,所述滚动条监听事件用于在滚动条滚动时获取滚动条的滚动高度;
数据限定单元,用于根据树形列表预设的长度值设置所述滚动盒子和所述列表盒子的高度和宽度;
节点索引单元,用于根据所述滚动盒子和所述列表盒子的高度和宽度,获得待渲染列表的节点索引集合;
节点获取单元,用于根据所述节点索引集合,在所述平铺树形列表中获取节点,创建节点标签,得到滚动列表。
在本发明实施例中,所述渲染模块270包括:
展开渲染单元,用于在所述子节点为收起状态时,取出当前节点中的所有子节点,依次向父节点的索引位置插入、修改并更新子节点显示状态并重新渲染树形列表,达到子节点展开效果;
收起渲染单元,用于在所述子节点为展开状态时,取出当前节点中子节点的长度,依次向父节点的索引位置后删除子节点长度数量的,若子节点内还有子节点,则根据其子节点的数量递归删除,修改并更新子节点显示状态并重新渲染树形列表,达到子节点收起效果。
关于树形列表的实现系统的具体限定可以参见上文中对于树形列表的实现方法的限定,在此不再赘述。上述树形列表的实现系统中的各个模块可全部或部分通过软件、硬件及其组合来实现。上述各模块可以硬件形式内嵌于或独立于计算机设备中的处理器中,也可以以软件形式存储于计算机设备中的存储器中,以便于处理器调用执行以上各个模块对应的操作。
请参阅图5,本发明实施例提供一种计算机终端设备,包括一个或多个处理器和存储器。存储器与所述处理器耦接,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如上述任意一个实施例中的树形列表的实现方法。
处理器用于控制该计算机终端设备的整体操作,以完成上述的树形列表的实现方法的全部或部分步骤。存储器用于存储各种类型的数据以支持在该计算机终端设备的操作,这些数据例如可以包括用于在该计算机终端设备上操作的任何应用程序或方法的指令,以及应用程序相关的数据。该存储器可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,例如静态随机存取存储器(Static Random Access Memory,简称SRAM),电可擦除可编程只读存储器(Electrically Erasable Programmable Read-OnlyMemory,简称EEPROM),可擦除可编程只读存储器(Erasable Programmable Read-OnlyMemory,简称EPROM),可编程只读存储器(Programmable Read-Only Memory,简称PROM),只读存储器(Read-Only Memory,简称ROM),磁存储器,快闪存储器,磁盘或光盘。
在一示例性实施例中,计算机终端设备可以被一个或多个应用专用集成电路(Application Specific 1ntegrated Circuit,简称AS1C)、数字信号处理器(DigitalSignal Processor,简称DSP)、数字信号处理设备(Digital Signal Processing Device,简称DSPD)、可编程逻辑器件(Programmable Logic Device,简称PLD)、现场可编程门阵列(Field Programmable Gate Array,简称FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述的树形列表的实现方法,并达到如上述方法一致的技术效果。
在另一示例性实施例中,还提供了一种包括程序指令的计算机可读存储介质,该程序指令被处理器执行时实现上述任意一个实施例中的树形列表的实现方法的步骤。例如,该计算机可读存储介质可以为上述包括程序指令的存储器,上述程序指令可由计算机终端设备的处理器执行以完成上述的树形列表的实现方法,并达到如上述方法一致的技术效果。
以上所述是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也视为本发明的保护范围。
Claims (4)
1.一种树形列表的实现方法,其特征在于,包括:
利用标签属性建立多层父子结构,得到原始树形结构;
将所述原始树形结构转化为平铺的单层数组结构;
将所述单层数组结构转化成数组标签,得到平铺树形列表;其中,所述数组标签能够通过深度属性区分显示样式;具体为:将单层数组结构导入预设数据逻辑,遍历参数后形成递归函数,得到平铺树形列表;
根据所述平铺树形列表,创建容器节点、滚动盒子和列表盒子;
根据所述容器节点、所述滚动盒子和所述列表盒子,完成树形列表滚动加载设计,得到滚动列表;具体为:为所述容器节点设置滚动条监听事件;其中,所述滚动条监听事件用于在滚动条滚动时获取滚动条的滚动高度;
根据树形列表预设的长度值设置所述滚动盒子和所述列表盒子的高度和宽度;
根据所述滚动盒子和所述列表盒子的高度和宽度,获得待渲染列表的节点索引集合;其中,索引值=(滚动高度-滚动盒子高度)/行高,可视区域的数量=滚动盒子高度/行高,所述节点索引集合为[索引值,索引值+1,…,索引值+可视区域的数量];
根据所述节点索引集合,在所述平铺树形列表中获取节点,创建节点标签,得到滚动列表;
在所述滚动列表的列表标签上注册点击事件,获取节点类型;
根据所述节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表;具体包括:当所述子节点为收起状态时,取出当前节点中的所有子节点,依次向父节点的索引位置插入、修改并更新子节点显示状态并重新渲染树形列表,达到子节点展开效果;当所述子节点为展开状态时,取出当前节点中子节点的长度,依次向父节点的索引位置后删除子节点长度数量,若子节点内还有子节点,则根据其子节点的数量递归删除,修改并更新子节点显示状态并重新渲染树形列表,达到子节点收起效果。
2.一种树形列表的实现系统,其特征在于,包括:
原始结构构造模块,用于通过标签属性建立多层父子结构,得到原始树形结构;
平铺模块,用于将所述原始树形结构转化为平铺的单层数组结构;
打标模块,用于将所述单层数组结构转化成数组标签,得到平铺树形列表;其中,所述数组标签能够通过深度属性区分显示样式;所述打标模块还用于将单层数组结构导入预设数据逻辑,遍历参数后形成递归函数,得到平铺树形列表;
节点构建模块,用于根据所述平铺树形列表,创建容器节点、滚动盒子和列表盒子;
滚动设计模块,用于根据所述容器节点、所述滚动盒子和所述列表盒子,完成树形列表滚动加载设计,得到滚动列表;
所述滚动设计模块包括:监听单元,用于为所述容器节点设置滚动条监听事件;其中,所述滚动条监听事件用于在滚动条滚动时获取滚动条的滚动高度;数据限定单元,用于根据树形列表预设的长度值设置所述滚动盒子和所述列表盒子的高度和宽度;节点索引单元,用于根据所述滚动盒子和所述列表盒子的高度和宽度,获得待渲染列表的节点索引集合;其中,索引值=(滚动高度-滚动盒子高度)/行高,可视区域的数量=滚动盒子高度/行高,所述节点索引集合为[索引值,索引值+1,…,索引值+可视区域的数量];节点获取单元,用于根据所述节点索引集合,在所述平铺树形列表中获取节点,创建节点标签,得到滚动列表;
节点分析模块,用于在所述滚动列表的列表标签上注册点击事件,获取节点类型;
渲染模块,用于根据所述节点类型分析子节点的状态,修改并更新子节点显示状态并渲染树形列表;所述渲染模块包括:
展开渲染单元,用于在所述子节点为收起状态时,取出当前节点中的所有子节点,依次向父节点的索引位置插入、修改并更新子节点显示状态并重新渲染树形列表,达到子节点展开效果;
收起渲染单元,用于在所述子节点为展开状态时,取出当前节点中子节点的长度,依次向父节点的索引位置后删除子节点长度数量,若子节点内还有子节点,则根据其子节点的数量递归删除,修改并更新子节点显示状态并重新渲染树形列表,达到子节点收起效果。
3.一种计算机终端设备,其特征在于,包括:
一个或多个处理器;
存储器,与所述处理器耦接,用于存储一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1所述的树形列表的实现方法。
4.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1所述的树形列表的实现方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110794479.0A CN113642292B (zh) | 2021-07-14 | 2021-07-14 | 一种树形列表的实现方法、系统、设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110794479.0A CN113642292B (zh) | 2021-07-14 | 2021-07-14 | 一种树形列表的实现方法、系统、设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN113642292A CN113642292A (zh) | 2021-11-12 |
CN113642292B true CN113642292B (zh) | 2022-06-14 |
Family
ID=78417329
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110794479.0A Active CN113642292B (zh) | 2021-07-14 | 2021-07-14 | 一种树形列表的实现方法、系统、设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113642292B (zh) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114491164B (zh) * | 2022-01-17 | 2022-12-09 | 广州市玄武无线科技股份有限公司 | 一种树形数据处理方法及系统 |
CN115408095B (zh) * | 2022-11-02 | 2022-12-23 | 北京滴普科技有限公司 | 基于动态分页技术展示大数据量的树数据的方法及系统 |
CN115455871B (zh) * | 2022-11-10 | 2023-03-24 | 北京云枢创新软件技术有限公司 | 大规模集成电路层次树展示系统 |
CN116931783A (zh) * | 2023-09-15 | 2023-10-24 | 中建三局信息科技有限公司 | 一种前端海量树形结构展示方法、装置、电子设备及介质 |
CN117648153B (zh) * | 2024-01-29 | 2024-04-26 | 太平金融科技服务(上海)有限公司 | 一种渲染展示方法、装置、电子设备和存储介质 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110825382A (zh) * | 2019-10-14 | 2020-02-21 | 紫光云(南京)数字技术有限公司 | 一种前端大数据树形结构展示方法 |
CN112506509A (zh) * | 2020-12-11 | 2021-03-16 | 杭州安恒信息技术股份有限公司 | 一种实现树形控件支持大数据渲染的方法及相关装置 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9317485B2 (en) * | 2012-01-09 | 2016-04-19 | Blackberry Limited | Selective rendering of electronic messages by an electronic device |
US10095671B2 (en) * | 2016-10-28 | 2018-10-09 | Microsoft Technology Licensing, Llc | Browser plug-in with content blocking and feedback capability |
CN112434030B (zh) * | 2020-11-11 | 2022-11-18 | 上海芯翌智能科技有限公司 | 基于树形结构数据的高性能列表实现方法与设备 |
-
2021
- 2021-07-14 CN CN202110794479.0A patent/CN113642292B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110825382A (zh) * | 2019-10-14 | 2020-02-21 | 紫光云(南京)数字技术有限公司 | 一种前端大数据树形结构展示方法 |
CN112506509A (zh) * | 2020-12-11 | 2021-03-16 | 杭州安恒信息技术股份有限公司 | 一种实现树形控件支持大数据渲染的方法及相关装置 |
Also Published As
Publication number | Publication date |
---|---|
CN113642292A (zh) | 2021-11-12 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN113642292B (zh) | 一种树形列表的实现方法、系统、设备及存储介质 | |
US9043698B2 (en) | Method for users to create and edit web page layouts | |
US5911145A (en) | Hierarchical structure editor for web sites | |
EP2249262A2 (en) | Visual hierarchy explorer | |
US8775923B1 (en) | Web page restoration | |
CN112506509B (zh) | 一种实现树形控件支持大数据渲染的方法及相关装置 | |
CN107479871B (zh) | 一种海量的矢量数据的访问和渲染方法、电子设备及存储介质 | |
US20050134589A1 (en) | Systems and methods for the estimation of user interest in graph theoretic structures | |
AU2005203708A1 (en) | Method, system, and computer-readable medium for creating and laying out a graphic within an application program | |
JP2008538038A (ja) | 明示的除外により範囲を指定するためのコンピュータ入力制御 | |
CN115455871B (zh) | 大规模集成电路层次树展示系统 | |
US9208249B2 (en) | Profiler for page rendering | |
CN109298905A (zh) | 利用前端编程语言优化图片懒加载的方法以及电子设备 | |
EP2189883B1 (en) | Method, apparatus and program for facilitating object selection on display screen | |
CN115686509A (zh) | 一种基于vue框架的树形结构数据渲染方法、装置和介质 | |
CN112464130B (zh) | 一种下拉选择框输入方法、装置、设备及介质 | |
CN112527288A (zh) | 可生成代码的可视化系统原型设计方法、系统及存储介质 | |
CN116955863A (zh) | 基于虚拟树的动态树形结构渲染方法及装置 | |
CN113822963A (zh) | 一种绘制及展示拓扑图的方法、系统、设备和存储介质 | |
US10013347B2 (en) | Non-blocking parallel memory mechanisms | |
CN116090555A (zh) | 一种知识图谱可视化的方法 | |
Dannenberg | A structure for efficient update, incremental redisplay and undo in graphical editors | |
CN117573125A (zh) | 一种树形结构数据渲染方法及装置 | |
JP2728977B2 (ja) | 統計量プロファイルの抽出方法、及び該方法によって作成した統計量の利用法 | |
CN118245692A (zh) | 加载web表格的方法、装置、计算机设备及存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |