当前位置: 首页 > news >正文

网站规划建设心得与体会新竹网站

网站规划建设心得与体会,新竹网站,注册公司注册地址怎么弄,百度快速排名软件下载大家好,今天我要分享的是如何在树形结构的数据中,根据特定条件设置节点及其所有子节点的显示属性。在实际项目中,这种需求非常常见,特别是在需要动态展示和隐藏节点的情况下。下面我将通过一个具体的示例来讲解实现过程。 需求分析…

大家好,今天我要分享的是如何在树形结构的数据中,根据特定条件设置节点及其所有子节点的显示属性。在实际项目中,这种需求非常常见,特别是在需要动态展示和隐藏节点的情况下。下面我将通过一个具体的示例来讲解实现过程。

需求分析

假设我们有一个树形结构的数据,如下所示:

 const treeData = [{name: "父节点1",id: 1,children: [{name: "子节点1-1", id: 11, children: [{name: "酸菜", id: 111, children: [{ name: "豆芽", id: 1111, }]}, { name: "豌豆", id: 12, }]},{ name: "子节点1-2", id: 13 }]},{name: "父节点2",id: 2,children: [{ name: "子节点2-1", id: 22, },{name: "子节点2-2",id: 23,children: [{ name: "子节点2-2-1", id: 24 }]}]}];

我们的需求是:当输入一个文本时,找到所有name属性包含该文本的节点,并将这些节点及其所有子节点和所有父节点的show属性设置为true

实现步骤

  1. 初始化节点显示属性

    在开始遍历之前,我们需要将所有节点的show属性初始化为false。这可以通过递归遍历实现。

  2. 递归遍历树形结构

    我们编写一个递归函数traverse,用于遍历树形结构。当找到包含特定文本的节点时,我们需要将该节点及其所有子节点和所有父节点的show属性设置为true

  3. 设置子节点显示属性

    为了实现这一功能,我们添加了一个内部函数setChildrenTrue,该函数递归地将所有子节点的show属性设置为true

代码实现

以下是实现上述需求的完整代码:

function setSearchText(text) {// 初始化所有节点的show属性为falsefunction setFalse(node) {node.show = false;if (node.children) {node.children.forEach(child => setFalse(child));}}// 递归遍历树形结构并设置节点及其子节点和父节点的show属性function traverse(node, parent) {if (node.name.includes(text)) {node.show = true;parents.forEach(parent => {parent.show = true;});function setChildrenTrue(child) {child.show = true;if (child.children) {child.children.forEach(grandChild => setChildrenTrue(grandChild));}}if (node.children) {node.children.forEach(child => setChildrenTrue(child));}} else if (node.children) {node.children.forEach(child => traverse(child,[...parents, node]));}}// 遍历树之前先设置所有节点的show属性为falsetreeData.forEach(node => setFalse(node));// 从根节点开始遍历treeData.forEach(node => {traverse(node, []);});
}// 示例:设置包含"酸菜"的节点及其所有子节点和父节点的show属性为true
setSearchText("酸菜");console.log(treeData);

 用于树形节点过滤筛选

通过以上代码,我们成功实现了在树形结构数据中根据特定条件设置节点及其所有子节点的显示属性,通过遍历treeData,生成对应的ul和li,并根据show属性隐藏或显示,就能通过input输入框实现树结构的节点过滤啦

http://www.yayakq.cn/news/839753/

相关文章:

  • 海盐建设局网站在PHP下安装wordpress
  • 15年做哪个网站能致富豆芽网站建设douyanet
  • 网站pv uv是什么意思南昌专业做网站
  • 东莞网站设计建设有限公司网站翻页代码
  • 河南中国建设厅官方网站乐山市规划和建设局门户网站
  • 免费门户网站制作广州小程序定制开发
  • 网站建设哪家好知道万维科技杭州公司展厅设计公司
  • 网站建设 三门峡做网站最烂公司
  • 做外卖有哪些网站工程建设的基本内容
  • 网站建设服务费属于什么科目工程材料价格查询
  • 简洁 手机 导航网站模板下载南宁seo霸屏
  • jsp做的网站怎嘛用百度账户托管
  • 手机网站的优势武城网站建设价格
  • 多人运动免费正能量网站链接海报生成免费
  • 吉林省高等级公路建设局 网站网站优化软件有哪些
  • 北京网站建设模板主题建网站软件下载
  • wordpress添加< iframe>seo网站设计
  • 郑州教育培训机构网站建设台州网站建设seo
  • 网站设计的公司皆选奇点网络苏州游玩攻略必去的地方
  • 显示危险网站怎么解决重庆招标网官网
  • 网站建设小程序公众号销售合肥网站建设政务区
  • 沈阳企业网站建设公司定制网站制作系统
  • 网站建设属于设备吗松江集团网站建设
  • 用软件做的网站权限网页制作基础教程第2版答案
  • 美容视频视频网站建设泰达人才网招聘网
  • 网站筹备建设情况软件网络推广方案
  • 东莞网站建设与网络推广外贸seo软件
  • 求个网站谢谢佛山高端网站
  • wordpress迁站到阿里云重庆网络优化平台
  • 知名的中文域名网站有哪些重庆网站建设联系电话