首先需要引入jQuery哈!

1. 要求用下面的格式制作目录, 结构如下:
<ul>
<li>xxxx</li>
<li>xxxx</li>
<ul>
<li>xxxx</li>
<li>xxxx</li>
<ul>
<li>xxxx</li>
<li>xxxx</li>
</ul>
</ul>
</ul>
2. 要求带锚点的, 要使用父节点ID+锚点做为链接

1. 后台返回的数据:

const newDirList = [
{
"catalogId": 1,
"catalogFid": 0,
"catalogName": "目录",
"child": [],
"anchor": ""
},
{
"catalogId": 2,
"catalogFid": 0,
"catalogName": "版权信息",
"child": [],
"anchor": ""
},
{
"catalogId": 3,
"catalogFid": 0,
"catalogName": "第1章",
"child": [
{
"catalogId": 301,
"catalogFid": 3,
"catalogName": "第1章第1节",
"child": [
{"catalogId": 30101, "catalogFid": 301, "catalogName": "第1章第1节第1段", "child": [], "anchor": ""},
{"catalogId": 30102, "catalogFid": 301, "catalogName": "第1章第1节第2段", "child": [], "anchor": ""},
{"catalogId": 30103, "catalogFid": 301, "catalogName": "第1章第1节第3段", "child": [], "anchor": ""},
{"catalogId": 30104, "catalogFid": 301, "catalogName": "第1章第1节第4段", "child": [], "anchor": ""}
],
"anchor": ""
},
{
"catalogId": 302,
"catalogFid": 3,
"catalogName": "第1章第2节",
"child": [
{"catalogId": 30201, "catalogFid": 302, "catalogName": "第1章第2节第1段", "child": [], "anchor": "sec01"},
{"catalogId": 30202, "catalogFid": 302, "catalogName": "第1章第2节第2段", "child": [], "anchor": "sec02"},
{"catalogId": 30203, "catalogFid": 302, "catalogName": "第1章第2节第3段", "child": [], "anchor": "sec03"},
{"catalogId": 30204, "catalogFid": 302, "catalogName": "第1章第2节第4段", "child": [], "anchor": "sec04"}
],
"anchor": ""
},
{
"catalogId": 303,
"catalogFid": 3,
"catalogName": "第1章第3节",
"child": [],
"anchor": ""
},
{
"catalogId": 304,
"catalogFid": 3,
"catalogName": "第1章第4节",
"child": [],
"anchor": ""
},
{
"catalogId": 305,
"catalogFid": 3,
"catalogName": "第1章第5节",
"child": [],
"anchor": ""
}
],
"anchor": ""
},
{
"catalogId": 4,
"catalogFid": 0,
"catalogName": "第2章",
"child": [],
"anchor": ""
},
{
"catalogId": 6,
"catalogFid": 0,
"catalogName": "后记",
"child": [],
"anchor": ""
}
]

2. javaScrip:

 function genLi(name, catalogId, anchor, catalogFid) {
return `
<li>
<a href="${anchor?catalogFid:catalogId}.xhtml${anchor?'#'+anchor:''}">${name}(${anchor?catalogFid:catalogId}.xhtml${anchor?'#'+anchor:''})</a>
</li>
`.trim();
}
function loopArray (arr) {
let $ul = $('<ul>');
arr.forEach(function(v){
let $li = $(genLi(v.catalogName, v.catalogId, v.anchor, v.catalogFid));
$ul.append($li);
if (v.child && v.child.length) {
$ul.append(loopArray(v.child));
}
});
return $ul.get(0).outerHTML;
}
loopArray(newDirList);

3. 生成出的HTML代码:

<ul>
<li>
<a href="1.xhtml">目录(1.xhtml)</a>
</li>
<li>
<a href="2.xhtml">版权信息(2.xhtml)</a>
</li>
<li>
<a href="3.xhtml">第1章(3.xhtml)</a>
</li>
<ul>
<li>
<a href="301.xhtml">第1章第1节(301.xhtml)</a>
</li>
<ul>
<li>
<a href="30101.xhtml">第1章第1节第1段(30101.xhtml)</a>
</li>
<li>
<a href="30102.xhtml">第1章第1节第2段(30102.xhtml)</a>
</li>
<li>
<a href="30103.xhtml">第1章第1节第3段(30103.xhtml)</a>
</li>
<li>
<a href="30104.xhtml">第1章第1节第4段(30104.xhtml)</a>
</li>
</ul>
<li>
<a href="302.xhtml">第1章第2节(302.xhtml)</a>
</li>
<ul>
<li>
<a href="302.xhtml#sec01">第1章第2节第1段(302.xhtml#sec01)</a>
</li>
<li>
<a href="302.xhtml#sec02">第1章第2节第2段(302.xhtml#sec02)</a>
</li>
<ul>
<li>
<a href="3020201.xhtml">第1章第2节第2段第1行(3020201.xhtml)</a>
</li>
<li>
<a href="3020202.xhtml">第1章第2节第2段第2行(3020202.xhtml)</a>
</li>
<li>
<a href="3020203.xhtml">第1章第2节第2段第3行(3020203.xhtml)</a>
</li>
<li>
<a href="3020204.xhtml">第1章第2节第2段第4行(3020204.xhtml)</a>
</li>
</ul>
<li>
<a href="302.xhtml#sec03">第1章第2节第3段(302.xhtml#sec03)</a>
</li>
<li>
<a href="302.xhtml#sec04">第1章第2节第4段(302.xhtml#sec04)</a>
</li>
</ul>
<li>
<a href="303.xhtml">第1章第3节(303.xhtml)</a>
</li>
<li>
<a href="304.xhtml">第1章第4节(304.xhtml)</a>
</li>
<li>
<a href="305.xhtml">第1章第5节(305.xhtml)</a>
</li>
</ul>
<li>
<a href="4.xhtml">第2章(4.xhtml)</a>
</li>
<li>
<a href="6.xhtml">后记(6.xhtml)</a>
</li>
</ul>

最新文章

  1. Atitit各种SDM 软件开发过程SDP sdm的ddd tdd bdd设计
  2. EntityFramework 连接字符串
  3. 1、SQL可搜索可排序可分页存储过程, 2、范围内的随机时间 适用于sql 2008以上
  4. aa4
  5. 利用Abot爬虫和visjs 呈现漫威宇宙
  6. 多线程&amp;多进程解析:Python、os、sys、Queue、multiprocessing、threading
  7. 一周一话题之一(EF-CodeFirst、MEF、T4框架搭建学习)
  8. lightoj 1038 Race to 1 Again
  9. akoj-1369 贪吃蛇
  10. 使用Ajax发送http请求(get&amp;post请求)
  11. Ubuntu下 安装MiniGUI
  12. Springboot 实现多环境配置
  13. Python对象迭代与反迭代相关问题与解决技巧
  14. dart字符串处理
  15. POJ 2376 Cleaning Shifts【贪心】
  16. QueenPuzzle-N皇后问题
  17. [转帖] 知乎: 为什么品牌机器里面的VTX都是关闭的..
  18. 利用WeX5给手机APP增加短信验证码功能
  19. 保存进程的pid 文件目录/var/run/
  20. 微软编程一小时 题目2: Longest Repeated Sequence

热门文章

  1. nginx 反向代理实现负载均衡*配置实战
  2. js 操作select和option常见用法
  3. flutter 自定义tabbar 给tabbar添加背景功能
  4. Linux 用户管理 与 文件权限
  5. linux常用命令---------------find
  6. C#中Math方法总结
  7. 【并行计算-CUDA开发】GPU---并行计算利器
  8. sha256算法原理
  9. nRF5 SDK Bootloader and DFU moudles(3)
  10. VMware一些概念