Skip to content

LiteTree 组件使用指南

核心特性

  • 轻量级
    • 无任何第三方依赖,体积小巧。
  • Markdown 友好
    • 使用基于缩进的 `lite` 格式,完美融入 Markdown。
  • 高度可定制
    • 支持自定义节点样式、标签、注释和图标。
  • 强大的变量系统
    • 支持定义和复用样式及图标。
  • 内置标记
    • 提供一组预设的标记符,用于表示不同的状态。

使用自定义图标

LiteTree 的一大特色是支持自定义图标,但这需要将 SVG 图像转换为 Base64 编码的 Data URI。

基础语法

创建简单树形结构

通过缩进(推荐使用 4 个空格)来表示层级关系。

基础树形结构
  • 公司架构
    • 行政中心
      • 总裁办
      • 人力资源部
    • 市场中心
      • 市场部
      • 销售部

md
<LiteTree>
公司架构
    行政中心
        总裁办
        人力资源部
    市场中心
        市场部
        销售部
</LiteTree>

添加状态标记

使用行尾注释 // 加上特定的符号,可以为节点添加状态标记。

标准标记符
  • 项目状态
    • 已完成任务 成功标记
    • +新增功能 添加标记
    • -废弃代码 删除标记
    • 发现错误 错误标记
    • *修改文件 修改标记
    • 重要项目 重要标记

md
<LiteTree>
项目状态
    已完成任务      //v    成功标记
    新增功能        //+    添加标记
    废弃代码        //-    删除标记
    发现错误        //x    错误标记
    修改文件        //*    修改标记
    重要项目        //!    重要标记
</LiteTree>

添加标签

在节点标题后紧随 (tag,tag,tag) 用来表示节点的标签,支持多个标签。

基础标签
  • 技术栈
    • 前端开发
      • Node.js项目JavaScriptTypeScriptReact
      • Vue.js项目VueVitePinia
    • 后端开发
      • API服务SpringExpressFastAPI

md
<LiteTree>
技术栈
    前端开发
        Node.js项目(JavaScript,TypeScript,React)
        Vue.js项目(Vue,Vite,Pinia)
    后端开发
        API服务({color:white;background-color:#ff9e9e;border:1px solid red}Spring,{color:white;background-color:#9e9eff;border:1px solid blue}Express,{color:white;background-color:#bfffbf;border:1px solid green}FastAPI)
</LiteTree>
带图标的标签
  • 代码仓库
    • 项目管理
      • 主仓库GitHubGitee
      • 镜像仓库备份仓库

md
<LiteTree>
// 定义图标
github=
gitee=
---
代码仓库
    项目管理
        主仓库([github]GitHub,Gitee)
        镜像仓库([gitee]备份仓库)
</LiteTree>

添加注释

使用 // 后面内容代表节点的注释,显示在最右侧。

基础注释
  • 项目文件
    • 配置文件
      • package.json 项目依赖配置
      • vite.config.js 构建配置文件
    • 源代码
      • main.js 应用入口文件
      • App.vue 根组件

md
<LiteTree>
项目文件
    配置文件
        package.json                // 项目依赖配置
        vite.config.js             // {color:white;background-color:#ff9e9e;border:1px solid red}构建配置文件
    源代码
        main.js                     // 应用入口文件
        App.vue                     // {color:blue;font-weight:bold}根组件
</LiteTree>
带图标和链接的注释
  • 开源项目
    • 文档站点
      • VitePress 现代静态站点生成器
      • Docusaurus Facebook开源文档框架
    • 前端工具
      • Vite 构建工具详情官网
      • Vue.js 渐进式JavaScript框架

md
<LiteTree>
// 定义图标
star=
yes=
---
开源项目
    文档站点
        VitePress                   // [star]现代静态站点生成器
        Docusaurus                  // [yes]Facebook开源文档框架
    前端工具
        Vite                        // 构建工具详情[官网:star](https://vitejs.dev/)
        Vue.js                      // [star]渐进式[yes]JavaScript框架
</LiteTree>

变量系统

定义样式变量 (#name=styles)

用于定义可复用的 CSS 样式。

样式变量
  • 项目文件
    • 关键文件
    • 已完成文件

md
<LiteTree>
// 定义样式变量
#important=color:red;font-weight:bold;background:#ffe6e6;padding:2px 6px;border-radius:3px;
#success=color:green;font-weight:bold;background:#e6ffe6;padding:2px 6px;border-radius:3px;
---
项目文件
    {#important}关键文件
    {#success}已完成文件
</LiteTree>

定义类变量 (.name=styles)

用于定义 CSS 类,便于统一样式。

类变量
  • 源代码
    • main.js
    • config.json

md
<LiteTree>
// 定义类变量
.folder=color:#1976d2;font-weight:500;
.file=color:#666;
---
{.folder}源代码
    {.file}main.js
    {.file}config.json
</LiteTree>

定义图标变量 (name=base64data)

使用 Base64 编码的 SVG 定义自定义图标。

图标变量
  • 前端项目
    • src
      • Header.vue
    • package.json

md
<LiteTree>
// 定义图标变量 (参见上面的转换指南)
folder=
file=
---
[folder] 前端项目
    [folder] src
        [file] Header.vue
    [file] package.json
</LiteTree>

完整示例

完整示例
  • CrychicDoc 项目
    • .vitepress 配置目录
      • config
        • index.ts 更新配置
      • plugins 自定义插件
        • custom-alert.ts 警告插件
      • theme
        • components Vue 组件
          • CustomAlert.vue 新组件
    • docs
      • zh 中文文档
        • styleList.md 需要更新
      • en 英文文档
        • litetree-guide.md 本指南
    • package.json 项目配置
    • README.md 重要文档

md
<LiteTree>
// 样式定义
#new=color:white;background:#4caf50;padding:1px 4px;border-radius:2px;font-size:12px;
#deprecated=color:white;background:#f44336;padding:1px 4px;border-radius:2px;font-size:12px;
.important=font-weight:bold;color:#1976d2;
// 图标定义
vue=
ts=
---
{.important}CrychicDoc 项目
    .vitepress                    // {.important}配置目录
        config
            [ts] index.ts         // {#new}更新配置
        plugins                   // {.important}自定义插件
            [ts] custom-alert.ts  // {#new}警告插件
        theme
            [vue] components      // {.important}Vue 组件
                [vue] CustomAlert.vue  // {#new}新组件
    docs
        zh                        // 中文文档
            styleList.md          // {#deprecated}需要更新
        en                        // 英文文档
            litetree-guide.md   // {#new}本指南
    package.json                  //v    项目配置
    README.md                     //!    {.important}重要文档
</LiteTree>

内联样式

直接颜色样式

使用 {color:value} 语法直接对文本应用样式:

内联颜色
  • 项目状态
    • 已完成功能
    • 进行中
    • 严重问题
    • 重要说明

md
<LiteTree>
项目状态
    {color:green}已完成功能
    {color:orange}进行中
    {color:red}严重问题
    {color:blue;font-weight:bold}重要说明
</LiteTree>

混合样式

结合变量、内联样式、图标和标记符:

完整示例
  • CrychicDoc 项目
    • .vitepress 配置目录
      • config
        • index.ts 更新配置
      • plugins 自定义插件
        • custom-alert.ts 警告插件
      • theme
        • components Vue 组件
          • CustomAlert.vue 新组件
    • docs
      • zh 中文文档
        • styleList.md 需要更新
      • en 英文文档
        • litetree-guide.md 本指南
    • package.json 项目配置
    • README.md 重要文档

md
<LiteTree>
// 样式定义
#new=color:white;background:#4caf50;padding:1px 4px;border-radius:2px;font-size:12px;
#deprecated=color:white;background:#f44336;padding:1px 4px;border-radius:2px;font-size:12px;
.important=font-weight:bold;color:#1976d2;
// 图标定义
vue=
ts=
---
{.important}CrychicDoc 项目
    .vitepress                    // {.important}配置目录
        config
            [ts] index.ts         // {#new}更新配置
        plugins                   // {.important}自定义插件
            [ts] custom-alert.ts  // {#new}警告插件
        theme
            [vue] components      // {.important}Vue 组件
                [vue] CustomAlert.vue  // {#new}新组件
    docs
        zh                        // 中文文档
            styleList.md          // {#deprecated}需要更新
        en                        // 英文文档
            litetree-guide.md   // {#new}本指南
    package.json                  //v    项目配置
    README.md                     //!    {.important}重要文档
</LiteTree>

高级功能

标签与注释组合使用

标签和注释可以同时使用,创建更丰富的节点信息。

标签注释组合
  • 产品开发计划
    • 核心功能Vue.jsTypeScriptHigh框架核心 - {#status}开发中
    • 用户界面CSSVuetifyMediumUI组件库 - {#status}设计阶段
    • API接口Node.jsExpress后端服务 - 待启动

md
<LiteTree>
// 定义图标和样式
#priority=color:white;background:#e91e63;padding:1px 4px;border-radius:2px;font-size:11px;
#status=color:white;background:#4caf50;padding:1px 4px;border-radius:2px;font-size:11px;
star=
---
产品开发计划
    核心功能(Vue.js,TypeScript,{#priority}High)    // [star]框架核心 - {#status}开发中
    用户界面(CSS,Vuetify,{#priority}Medium)       // UI组件库 - {#status}设计阶段
    API接口(Node.js,Express)                      // 后端服务 - 待启动
</LiteTree>

深层嵌套与复杂结构

LiteTree 支持任意深度的嵌套,适合表示复杂的层级结构。

复杂嵌套结构
  • 大型前端项目架构 微前端架构
    • 基础设施层 核心基础设施
      • 构建工具 开发工具链
        • webpack.config.js 主配置文件
        • babel.config.js JS转译配置
        • 插件扩展 自定义插件
          • custom-loader.js 自定义加载器
          • optimize-plugin.js 优化插件
      • 开发服务器 本地开发环境
        • dev-server.js 开发服务器配置
        • proxy.config.js 代理配置
    • 应用层 业务逻辑层
      • 页面组件 页面级组件
        • 用户管理 用户相关页面
          • UserList.vue 用户列表
          • UserDetail.vue 用户详情
          • UserForm.vue 用户表单
        • 订单管理 订单相关页面
          • OrderList.vue 订单列表
          • OrderTracking.vue 订单跟踪
      • 通用组件 可复用组件
        • Button.vue 按钮组件
        • Modal.vue 弹窗组件
        • DataTable.vue 数据表格
    • 服务层 数据服务层
      • API服务 外部接口
        • user.service.js 用户API服务
        • order.service.js 订单API服务
      • 状态管理 应用状态
        • store.js Vuex/Pinia存储
        • modules 状态模块

md
<LiteTree>
// 定义各种样式和图标
#module=color:white;background:#2196f3;padding:2px 6px;border-radius:3px;font-size:12px;
#component=color:white;background:#ff9800;padding:2px 6px;border-radius:3px;font-size:12px;
#utility=color:#666;background:#f5f5f5;padding:2px 6px;border-radius:3px;font-size:12px;
.folder=color:#1976d2;font-weight:500;
.file=color:#666;
---
{.folder}大型前端项目架构                         // {#module}微前端架构
    {.folder}基础设施层                          //! 核心基础设施
        {.folder}构建工具                        // 开发工具链
            webpack.config.js                   // 主配置文件
            babel.config.js                     // JS转译配置
            {.folder}插件扩展                     // 自定义插件
                custom-loader.js                // {#utility}自定义加载器
                optimize-plugin.js              // {#utility}优化插件
        {.folder}开发服务器                       // 本地开发环境
            dev-server.js                       // 开发服务器配置
            proxy.config.js                     // 代理配置
    {.folder}应用层                              // {#module}业务逻辑层
        {.folder}页面组件                         // 页面级组件
            {.folder}用户管理                     // 用户相关页面
                UserList.vue                    // {#component}用户列表
                UserDetail.vue                  // {#component}用户详情
                UserForm.vue                    // {#component}用户表单
            {.folder}订单管理                     // 订单相关页面
                OrderList.vue                   // {#component}订单列表
                OrderTracking.vue               // {#component}订单跟踪
        {.folder}通用组件                         // 可复用组件
            Button.vue                          // {#component}按钮组件
            Modal.vue                           // {#component}弹窗组件
            DataTable.vue                       // {#component}数据表格
    {.folder}服务层                              // {#module}数据服务层
        {.folder}API服务                         // 外部接口
            user.service.js                     // 用户API服务
            order.service.js                    // 订单API服务
        {.folder}状态管理                         // 应用状态
            store.js                            // Vuex/Pinia存储
            modules                             // 状态模块
</LiteTree>

常见用例

项目文件结构

项目结构
  • 我的项目
    • src 结构完成
      • +components 添加组件中
        • Header.vue 已完成
        • +Footer.vue 待办
      • pages
        • Home.vue 已完成
        • *About.vue 更新中
    • package.json 已配置
    • *vite.config.js 优化中
    • README.md 需要文档

md
<LiteTree>
// 文件类型样式
.folder=color:#1976d2;font-weight:500;
.file=color:#666;
.config=color:#f57c00;font-weight:500;
.doc=color:#8bc34a;
// 状态样式
#completed=color:green;background:#e6ffe6;padding:1px 3px;border-radius:2px;font-size:11px;
#inprogress=color:orange;background:#fff3e0;padding:1px 3px;border-radius:2px;font-size:11px;
#todo=color:red;background:#ffe6e6;padding:1px 3px;border-radius:2px;font-size:11px;
---
{.folder}我的项目
    {.folder}src                  //v    {#completed}结构完成
        {.folder}components       //+    {#inprogress}添加组件中
            {.file}Header.vue     //v    {#completed}已完成
            {.file}Footer.vue     //+    {#todo}待办
        {.folder}pages
            {.file}Home.vue       //v    {#completed}已完成
            {.file}About.vue      //*    {#inprogress}更新中
    {.config}package.json         //v    {#completed}已配置
    {.config}vite.config.js       //*    {#inprogress}优化中
    {.doc}README.md               //!    {#todo}需要文档
</LiteTree>

团队组织

团队结构
  • 开发团队
    • 前端团队 团队负责人: 张三
      • +React 开发者 团队扩充中
        • 李四 高级开发
        • 王五 初级开发
      • Vue 开发者 团队完整
        • 赵六 高级开发
        • 钱七 初级开发
    • 后端团队 团队负责人: 孙八
      • *API 开发 重构中
        • 周九 高级开发
        • 吴十 初级开发
      • 数据库团队 关键项目
        • 郑一 高级开发

md
<LiteTree>
// 团队角色样式
#lead=color:white;background:#1976d2;padding:2px 6px;border-radius:3px;font-size:12px;
#senior=color:#1976d2;background:#e3f2fd;padding:2px 6px;border-radius:3px;font-size:12px;
#junior=color:#666;background:#f5f5f5;padding:2px 6px;border-radius:3px;font-size:12px;
---
开发团队
    前端团队                      // {#lead}团队负责人: 张三
        React 开发者              //+    团队扩充中
            李四                  // {#senior}高级开发
            王五                  // {#junior}初级开发
        Vue 开发者                //v    团队完整
            赵六                  // {#senior}高级开发
            钱七                  // {#junior}初级开发
    后端团队                      // {#lead}团队负责人: 孙八
        API 开发                  //*    重构中
            周九                  // {#senior}高级开发
            吴十                  // {#junior}初级开发
        数据库团队                //!    关键项目
            郑一                  // {#senior}高级开发
</LiteTree>

VSCode 代码片段

项目包含 LiteTree 的完整 VSCode 代码片段,帮助您快速创建各种树形结构。

基础片段

片段前缀 描述 用途
@file-tree 基础树结构 创建简单的文件目录树
@file-tree-advanced 高级树结构 包含变量定义和样式的完整树
@lite-tree-with-tags 带标签的树 展示标签功能的树结构
@lite-tree-with-comments 带注释的树 展示注释功能的树结构

变量定义片段

片段前缀 描述 生成内容
@lite-style-var 样式变量定义 #name=color:value;background:value;
@lite-class-var 类变量定义 .name=color:value;font-weight:value;
@lite-icon-var 图标变量定义 name=data:image/svg+xml;base64,...

预设图标片段

片段前缀 图标类型 Base64编码
@icon-folder 文件夹图标 蓝色文件夹SVG
@icon-file 文件图标 通用文件SVG
@icon-js JavaScript图标 JS文件类型图标
@icon-ts TypeScript图标 TS文件类型图标
@icon-vue Vue.js图标 Vue组件图标
@icon-github GitHub图标 GitHub品牌图标
@icon-star 星标图标 金色星形图标

预设样式片段

片段前缀 描述 包含样式
@lite-status-styles 状态样式集 成功、警告、错误、信息状态样式
@lite-filetype-styles 文件类型样式 文件夹、文件、配置文件样式
@lite-priority-styles 优先级样式 高、中、低优先级标签样式

完整示例片段

使用代码片段创建的树结构
  • 项目根目录 代码片段演示
    • src 源代码目录
      • componentsVueReact组件库
      • utils 工具函数

md
<LiteTree>
// 通过 @lite-status-styles 生成的样式
#success=color:white;background:#4caf50;padding:2px 6px;border-radius:3px;font-size:12px;
#warning=color:white;background:#ff9800;padding:2px 6px;border-radius:3px;font-size:12px;
#error=color:white;background:#f44336;padding:2px 6px;border-radius:3px;font-size:12px;
// 通过 @icon-folder 等生成的图标
folder=
---
[folder] 项目根目录                        // {#success}代码片段演示
    src                                  // 源代码目录
        components({#warning}Vue,React)   // 组件库
        utils                            // {#error}工具函数
</LiteTree>