Javascript递归算法

一、首先来一道开胃菜,css方面问题

在前端方面,渲染列表数据的时候,可能会更改第一个或者最后一个的样式,又或者其中第几个的样式,怎么做呢?
其实很简单,便是使用last-child选择器相关知识。
问题是,有时候,我们使用last-child会出现失效的问题。
先来个实际场景:
目的:给最后一个class=”invalid”的元素添加背景色。

为啥会失效?主要问题就是最后有个class=”disturb”的元素。
使用last-child选择器必须要有个容器包裹,否则就会失效,把上面class=”invalid”元素再用一个div包裹起来便可以了。
改成以下便可以了

二、重点来了

list转树型数据

关于这一点,个人觉得前端一般不需要这么做,毕竟前端主要负责进行数据渲染,以及用户交互。
但将list转为树型数据,里面涉及到的算法,我们还是要了解一下的。
将list转为树型数据,一般用到的是递归跟多次遍历方法。
其他的方法便不多做介绍了。在此介绍掌握最高效的方法,一次遍历即可。

list数据

树型数据

为了实现这个目的,我们需要了解很多的知识点。
1、基本的原理
每条数据都要有相应的id跟pid
id指的是这条数据的主键(就这么理解吧),一定要是唯一的。
pid指的是这条数据的上级数据的主键id,(相当于组织机构中,上级组织机构的主键id)。
当每条数据满足具有id跟pid的时候,那便可以将数据转为树型结构。
2、JavaScript是弱类型语言。举个例子:

3、引用类型(这个便是重中之重了,也是为啥一次遍历便能够实现想要的结果的原因)
引用类型,变量存储的是地址,而地址对应的是值,我们需要做的是改变值,但这个变量名称是不变的,也就是地址是不变的,值是改变的。
通过定义一个变量itemMap,动态地给itemMap添加id属性值,而itemMap属性的值为list中的一个数组对象,并且循环遍历的时候,不断给itemMap属性值添加相应的children。

详细代码如下:

树型数据转list(倒过来)

这个,暂时没想到什么更好的方法,便用递归实现了。
递归,有个很形象的说法,一层一层地拨开你的心!!!

三、扩展(递归的使用,巩固递归算法)

给树型数据每项添加额外的数据

四、总结

递归算法,还是很有必要掌握的,在树型结构方面经常会用到。

希望疫情早点结束!!!

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注