代码拉取完成,页面将自动刷新
/**
* 用于生成目录列表
*/
'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;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。