您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
ctrl+s保存ppt,ctrl+d查看ppt
// ==UserScript== // @name 超星学习通章节内ppt下载 // @namespace http://tampermonkey.net/ // @version 1.0 // @description ctrl+s保存ppt,ctrl+d查看ppt // @author white // @match https://mooc1.chaoxing.com/mycourse/* // @icon  // @grant none // @license MIT // ==/UserScript== (function () { "use strict"; function getPdfInfo() { try { var objectId = document .getElementsByTagName("iframe")[0] .contentDocument.body.getElementsByClassName("ans-attach-ct")[0] .getElementsByTagName("iframe")[0] .getAttribute("objectid"); } catch (e) { window.alert("获取objectId失败!"); throw new Error("获取objectId失败!"); } var url = `https://mooc1.chaoxing.com/ananas/status/${objectId}?flag=normal&_dc=${Date.now()}`; var xhr = new XMLHttpRequest(); xhr.open("GET", url, false); xhr.send(); var data = JSON.parse(xhr.responseText); return { pdfUrl: data.pdf, fileName: (data.filename += ".pdf"), }; } function createStyle() { var styleElement = document.createElement("style"); styleElement.type = "text/css"; var cssRules = ` #__w_progressBarWrp { width: 100%; background-color: #f3f3f3; height: 30px; text-align: center; line-height: 30px; color: white; } #__w_progressBar{ background-color: #4caf50; } /* 弹窗样式 */ #__w_myModal { display: none; position: fixed; z-index: 99999; left: 0; top: 0; width: 100%; height: 100%; overflow: auto; background-color: rgba(0, 0, 0, 0.4); } #__w_modal-content { background-color: #fefefe; margin: 15% auto; padding: 20px; border: 1px solid #888; width: 300px; text-align: center; position: relative; } /* 关闭按钮样式 */ #__w_close { color: #aaa; position: absolute; top: 0; right: 15px; font-size: 28px; font-weight: bold; cursor: pointer; } #__w_close:hover, #__w_close:focus { color: black; text-decoration: none; } #__w_fileName { width: 200px; /*超出隐藏*/ overflow: hidden; /*超出不换行*/ white-space: nowrap; /*超出使用...*/ text-overflow: ellipsis; } #__w_boardPreview{ z-index: 9999; position: fixed; top: 50px; right: 100px; display: flex; flex-direction: column; }`; styleElement.appendChild(document.createTextNode(cssRules)); document.head.appendChild(styleElement); } function createProgressDiv() { const divContent = ` <div id="__w_modal-content"> <span id="__w_close">×</span> <p id="__w_fileName"></p> <div id="__w_progressBarWrp"> <div id="__w_progressBar"></div> </div> </div>`; const newDiv = document.createElement("div"); // 设置div的内容 newDiv.innerHTML = divContent; newDiv.id = "__w_myModal"; // 将div添加到body中 document.body.appendChild(newDiv); } function createBtnDiv() { const divContent = ` <button id="__w_downloadPdf">下载课件</button> <button id="__w_previewDdf">预览课件</button> `; const newDiv = document.createElement("div"); // 设置div的内容 newDiv.innerHTML = divContent; newDiv.id = "__w_boardPreview" // 将div添加到body中 document.body.appendChild(newDiv); } function previewPdf() { const data = getPdfInfo(); window.open(data.pdfUrl, "_blank"); } function downlodePdf() { const data = getPdfInfo(); showText(data.fileName + "下载中..."); modal.style.display = "block"; xhr = new XMLHttpRequest(); xhr.open("GET", data.pdfUrl, true); xhr.responseType = "blob"; // 监听响应进度 xhr.addEventListener("progress", function (event) { if (event.lengthComputable) { const percentComplete = (event.loaded / event.total) * 100; progressBar.style.width = percentComplete + "%"; progressBar.textContent = Math.round(percentComplete) + "%"; } }); // 监听请求响应 xhr.onreadystatechange = function () { if (xhr.readyState == 4) { if (xhr.status == 200) { // 获取响应的blob对象 var blob = xhr.response; // 创建下载链接 var downloadUrl = window.URL.createObjectURL(blob); var a = document.createElement("a"); a.href = downloadUrl; a.download = data.fileName; document.body.appendChild(a); a.click(); document.body.removeChild(a); // 释放URL对象 window.URL.revokeObjectURL(downloadUrl); closeSuccess() } else { const text = "下载失败:" + xhr.statusText; console.error("下载失败:", xhr.statusText); showText(text); } } }; xhr.onerror = function () { console.error("请求出错"); showText("请求出错"); closeSuccess(); }; xhr.send(); } createStyle(); createProgressDiv(); createBtnDiv(); const modal = document.getElementById("__w_myModal"); document.getElementById("__w_close").onclick = function () { if (xhr && xhr.readyState !== XMLHttpRequest.DONE) { xhr.abort(); } closeSuccess(); }; const progressBar = document.getElementById("__w_progressBar"); const fileNameP = document.getElementById("__w_fileName"); document.getElementById("__w_downloadPdf").onclick = downlodePdf; document.getElementById("__w_previewDdf").onclick = previewPdf; let xhr; function closeSuccess() { progressBar.style.width = 0; progressBar.textContent = ""; modal.style.display = "none"; } function showText(msg) { msg = msg ? msg : "文件下载中..."; fileNameP.innerHTML = msg; } document.addEventListener("keydown", function (event) { if (event.ctrlKey && event.key === "d") { event.preventDefault(); previewPdf() } else if (event.ctrlKey && event.key === "s") { event.preventDefault(); downlodePdf() } }); })();