antd+js 目录树实现

简介: antd+js 目录树实现

antd 目录树实现

话不说多 先看图

首先我们这里是要在项目内做一个编辑器功能。做编辑器目录树就必不可少。如何根据多维数组作出自己想要的目录结构,请看下面代码

const data = [
    {
        catalog:'目录一',
        isDirectory:true
          child:[
              {
                  childCatalog:'子目录一',
                  isDirectory:true
                  childChild:[...里面可能还有很多]
              },
              {
                  childCatalog:'子目录二',
                  isDirectory:trueÏ
              },
          ]  
    },
    {
        catalog:'目录二',
        isDirectory:false
    }
]
//大致数据结构如上
    function forList(data) {
        let showView = []
        for (let i in data) {
            if (data[i].isDirectory && data[i].childs) {
                //是目录 并且有子目录
                let obj =
                    <SubMenu key={'one' + data[i].name} title={data[i].name} 
                    draggable="true"
                    onContextMenu={() => {
                        onContextMenuClick(data[i])
                    }}>
                        {forList(data[i].childs)}
                    </SubMenu>
                showView.push(obj)
            } else if (!data[i].isDirectory) {
                //是文件
                let obj = <Menu.Item key={'file' + data[i].name} onClick={() => { onMenuClick(data[i]) }}>{data[i].name}</Menu.Item>
                showView.push(obj)
            } else {
                //是目录,但是没子目录
                let obj = <SubMenu key={'fileno' + data[i].name} title={data[i].name}>
                </SubMenu>
                showView.push(obj)
            }
        }
        return showView
    }
目录
相关文章
|
8月前
|
JavaScript 前端开发 安全
使用 Node.js 插件给指定目录下的所有图片添加上文字水印
使用 Node.js 插件给指定目录下的所有图片添加上文字水印
179 0
|
5月前
|
JavaScript Java
点击按钮,向下添加目录。Java script+jQuery写法
点击按钮,向下添加目录。Java script+jQuery写法
31 1
|
6月前
|
算法 JavaScript
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
87 0
JS 【详解】树的遍历(含深度优先遍历和广度优先遍历的算法实现)
|
7月前
|
JavaScript 前端开发 算法
虚拟DOM是React的关键技术,它是个轻量的JS对象树,模拟实际DOM结构。
【6月更文挑战第27天】虚拟DOM是React的关键技术,它是个轻量的JS对象树,模拟实际DOM结构。当状态改变,React不直接修改DOM,而是先构建新的虚拟DOM树。通过 diff 算法比较新旧树,找到最小变更,仅更新必要部分,提高性能,避免频繁DOM操作。虚拟DOM还支持跨平台应用,如React Native。它优化了更新流程,简化开发,并提升了用户体验。
47 1
|
6月前
|
JavaScript
js 解析和操作树 —— 获取树的深度、提取并统计树的所有的节点和叶子节点、添加节点、修改节点、删除节点
js 解析和操作树 —— 获取树的深度、提取并统计树的所有的节点和叶子节点、添加节点、修改节点、删除节点
159 0
|
8月前
|
前端开发 JavaScript 算法
JavaScript 中实现常见数据结构:栈、队列与树
JavaScript 中实现常见数据结构:栈、队列与树
|
8月前
|
JavaScript
node.js 删除某个目录下所有的文件夹
node.js 删除某个目录下所有的文件夹
140 0
|
JavaScript
使用JS 实现二叉查找树(Binary Search Tree)
使用JS 实现二叉查找树(Binary Search Tree)
78 0
|
8月前
|
JavaScript
理解DOM树的加载过程(js的问题)
理解DOM树的加载过程(js的问题)
34 0
|
JavaScript 前端开发
Gulp 打包压缩 js 文件到指定目录详细流程(修改文件名与后缀)
Gulp 打包压缩 js 文件到指定目录详细流程(修改文件名与后缀)
223 0