yuque-html-exporter

export yuque document to html.

当前为 2023-08-11 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name yuque-html-exporter
  3. // @namespace https://github.com/zenonux
  4. // @version 1.2
  5. // @description export yuque document to html.
  6. // @author 换个头像心好累
  7. // @license GPL-3.0 License
  8. // @match *://*.yuque.com/*
  9. // @icon 
  10. // @require https://cdn.jsdelivr.net/npm/markdown-it@13.0.1/dist/markdown-it.min.js
  11. // @grant none
  12. // ==/UserScript==
  13.  
  14. (function () {
  15. "use strict";
  16.  
  17. init();
  18.  
  19. function init() {
  20. let btn = document.createElement("button");
  21. btn.id = "exportHtmlButton";
  22. btn.innerText = "导出html";
  23. btn.style =
  24. "position:fixed;top:5px;left:50%;transform:translate(-50%,0);z-index:10000;background:#00b96b;padding:10px 14px;border:none;color:#fff;cursor:pointer;";
  25.  
  26. var md = window.markdownit({
  27. html: true,
  28. });
  29.  
  30. btn.addEventListener("click", () => {
  31. const mdDownloadUrl =
  32. window.location.href +
  33. "/markdown?attachment=true&latexcode=false&anchor=true&linebreak=true";
  34. window
  35. .fetch(mdDownloadUrl)
  36. .then((res) => res.text())
  37. .then((html) => {
  38. _copyToClipboard(md.render(html)).then(() => {
  39. _showToast("已导出至剪切板");
  40. });
  41. });
  42. });
  43.  
  44. document.body.appendChild(btn);
  45. _toggleBtn();
  46.  
  47. history.pushState = _bindEventListener("pushState");
  48. history.replaceState = _bindEventListener("replaceState");
  49. window.addEventListener("replaceState", function () {
  50. _toggleBtn();
  51. });
  52. window.addEventListener("pushState", function () {
  53. _toggleBtn();
  54. });
  55. }
  56.  
  57. function _toggleBtn() {
  58. let btn = document.getElementById("exportHtmlButton");
  59. if (btn) {
  60. btn.style.display = "none";
  61. }
  62. setTimeout(() => {
  63. let isAtDetailPage = document.querySelector(".ne-doc-major-viewer");
  64. if (!isAtDetailPage) {
  65. if (btn) {
  66. btn.style.display = "none";
  67. }
  68. } else {
  69. if (btn) {
  70. btn.style.display = "block";
  71. }
  72. }
  73. }, 2000);
  74. }
  75.  
  76. function _bindEventListener(type) {
  77. const historyEvent = history[type];
  78. return function () {
  79. const newEvent = historyEvent.apply(this, arguments);
  80. const e = new Event(type);
  81. e.arguments = arguments;
  82. window.dispatchEvent(e);
  83. return newEvent;
  84. };
  85. }
  86.  
  87. function _showToast(msg) {
  88. let toast = document.createElement("div");
  89. toast.innerText = msg;
  90. toast.style =
  91. "position:fixed;top:16%;left:50%;transform:translate(-50%,-24%);z-index:20000;background:#67C23A;padding:30px 45px;border-radius:4px;color:#fff;";
  92. document.body.appendChild(toast);
  93. setTimeout(() => {
  94. document.body.removeChild(toast);
  95. }, 1000);
  96. }
  97.  
  98. function _copyToClipboard(text) {
  99. return navigator.clipboard.writeText(text);
  100. }
  101. })();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址