js/微信小程序|实现多级目录,可展开折叠

前言:

项目简介:项目是关于知识学习的培训平台,有课程和资料模块,课程和资料的详情页均展示对应的课程或资料目录,目录支持多层级(无限层级),展示方式与B站上的视频目录同理,只不过我们需要无限级。如果一个层级目录下有好几个子级,点击这个层级目录可以展开或折叠。点击对应的子级目录时,当前被点击的那条要变色,代表此时正在看。

一、项目中想要的效果

下图展示项目中需要实现的效果:

右侧的按钮支持展开与折叠:

二、实现思路

我们可以将此功能作为组件抽离出来,因为目录是无限层级的,每一个子级都会比父级缩进一定间距。每一层级样式也都差不多,只是背景色和字体需要调整一下。

三、接口返回的数据结构

附上接口返回的数据结构,帮助理解:

三、实现方案

备注:此处将以微信小程序项目作为示例进行演示说明。

  1. 首先将目录部分作为组件使用,组件命名为chapterList,然后在详情页引入:
wxml 复制代码
<!-- 资料目录 -->
<view class="courseList">
  <view class="subtitle">资料列表</view>
  <block wx:for="{{detailsList}}" wx:key="index">
    <chapterList listData="{{item}}" step="1" playCourseChapterId="{{courseInfo.playCourseChapterId}}" classification="{{courseInfo.classification}}" bindgetFileId="getNewFileId"></chapterList>
  </block>
</view>
js 复制代码
  // 查看资料详情
  getCourseInfo:function(){
    var that = this
    https.get(api.getCourseInfo, obj).then((res) => {
      const returndata = res.data
      let detailsList = this.formatList(returndata.details, returndata.playCourseChapterId)
      that.setData({
        playCourseChapterId: returndata.playCourseChapterId, // 初始赋值
        courseInfo: returndata,
        detailsList,
      });
    })
  },

其中,formatList方法是用来判断选中的是哪条数据,根据唯一值playCourseChapterId来判断。然后手动给此对象加一个属性selected,后面会用来做样式的判断,代码如下:

js 复制代码
  formatList(list = [], playCourseChapterId) {
    circle(list)
    function circle(_list) {
      _list.forEach(item => {
        if (item.children && item.children.length) {
          circle(item.children)
        } else {
          item.selected = false
          if (item.chapterId === playCourseChapterId) {
            item.selected = true
          }
        }
      })
    }
    return list
  },
  1. chapterList组件中也要引用chapterList组件:
  1. chapterList组件中获取上面的select的值,添加不同的样式,如果select=true,根据需求展示被选中的样式,比如我们的需求是,字体颜色变蓝。
  2. 需要注意的是,所有需要父子组件传的事件,也要在chapterList组件中再接收一遍。

最后,希望对大家有帮助!

相关推荐
haierccc30 分钟前
Win7、2008R2、Win10、Win11使用FLASH的方法
前端·javascript·html
We་ct33 分钟前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
Hilaku39 分钟前
卷AI、卷算法、2026 年的前端工程师到底在卷什么?
前端·javascript·面试
军军君011 小时前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维
四千岁1 小时前
Ollama+OpenWebUI 最佳组合:本地大模型可视化交互方案
前端·javascript·后端
写不来代码的草莓熊1 小时前
el-date-picker ,自定义输入数字自动转换显示yyyy-mm-dd HH:mm:ss格式
前端·javascript·vue.js
Wect1 小时前
JS手撕:手写Koa中间件与Promise核心特性
前端·javascript·面试
张元清2 小时前
React 文件处理:上传、拖放区与对象 URL
前端·javascript·面试
煜bart2 小时前
使用 TypeScript 实现算法处理
开发语言·前端·javascript
打瞌睡的朱尤2 小时前
微信小程序1~25
微信小程序·小程序