您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
EPUB目前支持比较简陋
// ==UserScript== // @name HyReadTW下载器 // @namespace https://qinlili.bid // @version 0.1 // @description EPUB目前支持比较简陋 // @author 琴梨梨 // @match https://service.ebook.hyread.com.tw/ebookservice/epubreader/hyread/v3/reader.jsp // @icon https://nju.ebook.hyread.com.cn/Template/standard/images/hyread_icon.jpg // @grant none // @run-at document-end // @require https://cdn.jsdelivr.net/npm/[email protected]/dist/jszip.min.js // @license MPLv2 // ==/UserScript== (async function() { 'use strict'; console.log("正在初始化喵~"); const dlFile = (link, name) => { let eleLink = document.createElement('a'); eleLink.download = name; eleLink.style.display = 'none'; eleLink.href = link; document.body.appendChild(eleLink); eleLink.click(); document.body.removeChild(eleLink); } function waitUI() { return new Promise(resolve => { const observer = new MutationObserver(function(){ if(document.getElementsByClassName("render").length){ console.log("页面就绪了喵~走起~"); resolve(); observer.disconnect(); } }); observer.observe(document.documentElement, {childList: true,subtree: true }); }); }; const originCreate=URL.createObjectURL; let imgTemp=[] var onPageChange = function () { }; function waitLoading() { return new Promise(resolve => { setTimeout(()=>{resolve()},10000); onPageChange = () => { resolve(); } }); } let num=0; const count=()=>{ num++; if(num==2){ onPageChange(); num=0; } } URL.createObjectURL=object=>{ console.log(object); imgTemp[imgTemp.length]=object; count(); return originCreate(object); }; await waitUI(); const nextPage=()=>{ document.body.dispatchEvent(new KeyboardEvent("keyup",{ bubbles: true, cancelable: true, code: "ArrowRight", key: "ArrowRight", keyCode: 39 })) }; const nextPageLeft=()=>{ document.body.dispatchEvent(new KeyboardEvent("keyup",{ bubbles: true, cancelable: true, code: "ArrowLeft", key: "ArrowLeft", keyCode: 37 })) }; const sleep = delay => new Promise(resolve => setTimeout(resolve, delay)) console.log("准备中~"); await sleep(2000); //推断类名 const svgList=document.getElementsByTagName("svg"); //建立下载按钮 let dlBtn=document.createElement("div"); dlBtn.className=svgList[6].parentElement.className; let dlIcon=document.createElement("img"); dlIcon.src=""; dlBtn.appendChild(dlIcon); svgList[6].parentElement.insertAdjacentElement('afterend',dlBtn); let clickTick=0; dlBtn.addEventListener("click",async ()=>{ if(!clickTick){ console.log("要开始了哟~"); alert("请手动翻页,确保载入完成后再继续翻页,直到末尾,然后再次点击下载按钮"); clickTick++; }else{ alert("正在打包"); console.log("在打包了喵~"); let zip = new JSZip(); let counter=0; imgTemp.forEach(imgBlob=>{ counter++ if(imgBlob.type.indexOf("image")==1){ zip.file(counter+ ".jpg", imgBlob, { binary: true }) }else{ zip.file(counter+ ".html", imgBlob, { binary: true }) } }); let zipFile=await zip.generateAsync({ type: "blob" }); dlFile(originCreate(zipFile),"000.zip"); console.log("完成了喵~"); } }) console.log("准备就绪了喵~"); })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址