hexo-theme-nexmoe
Version:
🔥 A special hexo theme.
52 lines (42 loc) • 1.8 kB
JavaScript
window.addEventListener('load', () => {
const codeBlocks = document.querySelectorAll('figure.highlight');
if (!codeBlocks.length) return;
const addCopyButton = codeBlock => {
const copyWrapper = document.createElement('div');
copyWrapper.setAttribute('class', 'codeblock-copy-wrapper');
let copiedTimeout = null;
copyWrapper.addEventListener('click', ev => {
const highlightDom = ev.target.parentElement;
const code = highlightDom.querySelector('code');
let copiedCode = '';
(function traverseChildNodes(node) {
const childNodes = node.childNodes;
childNodes.forEach(child => {
switch (child.nodeName) {
case '#text': // 文本节点
copiedCode += child.nodeValue;
break;
case 'BR': // <br />
copiedCode += '\n';
break;
default:
traverseChildNodes(child);
}
});
}(code));
navigator.clipboard.writeText(
/* 去掉最后的换行 */
copiedCode.slice(0, -1)
).then(() => {
if (copiedTimeout) clearTimeout(copiedTimeout);
copyWrapper.classList.add('codeblock-copy-wrapper-copied');
copiedTimeout = setTimeout(() => {
copyWrapper.classList.remove('codeblock-copy-wrapper-copied');
copiedTimeout = null;
}, 1500);
});
});
codeBlock.appendChild(copyWrapper);
};
codeBlocks.forEach(addCopyButton);
});