1 Star 0 Fork 0

CPC123456/canvas-test

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
menu.js 2.40 KB
一键复制 编辑 原始数据 按行查看 历史
吖猩 提交于 2018-04-10 01:39 +08:00 . chore: update menu
/**
* 用于生成目录列表
*/
'use strict';
const fs = require('fs');
const path = require('path');
const base = 'src/';
const pagePreFix = 'http://whxaxes.github.io/canvas-test/';
const sourcePrefix = 'https://github.com/whxaxes/canvas-test/tree/master/';
const files = fs.readdirSync(base);
let html = fs.readFileSync('./menu.html').toString();
let readme = fs.readFileSync('./README.md').toString();
let ul_html = '<div class="view">';
let md_value = '| 标题 | |\n|:-------- |:--------:|\n';
const mlList = [
'Funny-demo',
'Particle-demo',
'Game-demo',
'3D-demo',
'Other-demo',
];
// 对文件夹更改进行排序
files.sort(function(a, b) {
let astat = fs.lstatSync(base + a);
let bstat = fs.lstatSync(base + b);
return bstat.mtime - astat.mtime;
});
// 添加列表内容
mlList.forEach(function(f) {
var npath = path.join(base, f);
var array = findHtml(npath);
array.sort(function(a, b) {
return b[2].mtime - a[2].mtime;
});
if (array.length > 0) {
ul_html += `<p>${f}</p><ul class='main'>`;
array.forEach(function(p) {
const title = /<title>(.*)<\/title>/.test(
fs.readFileSync(p[0]).toString()
)
? RegExp.$1
: 'Document';
const address = pagePreFix + p[0];
const filedir = path.dirname(sourcePrefix + p[0]);
ul_html += `
<li>
<a href='${
p[0]
}' target='_blank' class='demo-name' title='效果预览'>${title}</a><a href='${filedir}' class='demo-source' target='_blank' title='点击查看源码'>源码</a>
</li>
`;
md_value += `| [${title}](${address}) | [查看代码](${filedir}) |\r`;
});
ul_html += '</ul>';
}
});
ul_html += '</div>';
html = html.replace(/(<body>)[\s\S]*?(<\/body>)/, '$1' + ul_html + '$2');
readme = readme.replace(
/(\[placeholder]:p)[\s\S]*?(\[\/placeholder]:p)/,
'$1\n\n' + md_value + '\n\n$2'
);
fs.writeFileSync('./menu.html', html);
fs.writeFileSync('./README.md', readme);
function findHtml(folder_path, collector) {
collector = collector || [];
let files = fs.readdirSync((folder_path += '/'));
let npath, stat;
files.forEach(function(f) {
npath = folder_path + f;
stat = fs.lstatSync(npath);
if (stat.isDirectory()) {
findHtml(npath, collector);
return;
}
if (/^[^_].+\.html/.test(f)) {
collector.push([npath, f, stat]);
}
});
return collector;
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/cpc12345/canvas-test.git
git@gitee.com:cpc12345/canvas-test.git
cpc12345
canvas-test
canvas-test
master

搜索帮助