您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
這是在 hitomi.la 網站上運作的腳本,主要是將網頁中的類型、語言、分類標籤和系列英語部分換成中文,以便於了解作品的資訊。
// ==UserScript== // @name hitomi.la_zh-TW // @namespace hitomi.la TW // @description 這是在 hitomi.la 網站上運作的腳本,主要是將網頁中的類型、語言、分類標籤和系列英語部分換成中文,以便於了解作品的資訊。 // @version 13.4 // @include *://hitomi.la/* // @compatible chrome >=55 // @icon https://ltn.hitomi.la/apple-touch-icon-57x57.png // ==/UserScript== const TranslatioDataURL = "https://raw.githubusercontent.com/zxc129567142/hitomi.la_zh-TW/master/TranslatioData.min.json"; let topbar = {}, booktypes = {}, lang = {}, bookseries = {}, booktags = {}, // 修改 Daily 的值能夠改變更新翻譯數據的頻率 // 預設值 7 Daily = 7, nowTime = (new Date).getTime(), TimeD = 0, url = location.pathname; // 變數 url 設成當前網址路徑部分 const tEng = { // 將標題轉成網址格式 h3ToURL: str => { str = str.toLowerCase(); return (str === "recently added") ? "index" : str // encodeURI(str).replace(/\./g, "%2E").replace(/\-/g, "%2D"); }, // 簡單判斷翻譯工作區 tocht: (chgThis, txt, cht) => { if (chgThis.textContent.match(txt)) { chgThis.title = txt; chgThis.textContent = cht } }, // 用於 頂部分類類型 topbar: topbar_obj => { const topbartext = topbar_obj.textContent; if (topbar[topbartext]) { topbar_obj.title = topbartext; topbar_obj.textContent = topbar[topbartext]; } }, //用於 頂部語言 // //var lang = { // lang_eng: { // "cht": lang_cht, // "url": lang_url // }, //} topbarLang: lang_obj => { const toplangtext = lang_obj.textContent; const h3 = document.querySelector("h3"); const Title_h3 = h3.getAttribute("title") || h3.textContent; const weburl = url.match("\/(galleries|manga|anime|doujinshi|gamecg|cg)\/"); if (!lang[toplangtext]) { console.log(toplangtext); return false } const lang_url = lang[toplangtext].url; // console.log(lang_obj.innerHTML.match(lang_url) , lang_obj.innerHTML === toplangtext); const RegExpUrl = new RegExp((tEng.h3ToURL(Title_h3) === "index" && lang_url === "all") ? "^\/$" : "(" + tEng.h3ToURL(Title_h3) + "\-" + lang_url + ")", "g"); if (RegExpUrl.test(lang_obj.getAttribute("href")) || weburl) { lang_obj.title = toplangtext + " \( " + lang_url + " \)"; lang_obj.textContent = lang[toplangtext].cht; } }, //用於 語言 lang: lang_obj => { const langText = lang_obj.textContent; if (lang[langText]) { lang_obj.title = langText + " \(" + lang[langText].url + "\)"; lang_obj.textContent = lang[langText].cht; return; } lang_obj.title = langText.toUpperCase(); }, //用於 類型 types: types_obj => { const typeText = types_obj.textContent.replace(/(^\s+)|(\s+$)/g, ""); if (booktypes[typeText]) { types_obj.title = typeText; types_obj.textContent = booktypes[typeText]; return; } types_obj.title = typeText.toUpperCase(); }, //用於 系列 series: series_obj => { const seriesText = series_obj.textContent; if (bookseries[seriesText]) { series_obj.title = seriesText; series_obj.textContent = bookseries[seriesText]; return; } series_obj.title = seriesText.toUpperCase(); }, //用於 標籤 tags: tags_obj => { const tagText = tags_obj.textContent; if (booktags[tagText]) { tags_obj.title = tagText; tags_obj.textContent = booktags[tagText]; return; } tags_obj.title = tagText.toUpperCase(); } }; (function () { "use strict"; localStorage.setItem("hitomi.la_zh-TW", "loading"); // 只要有任何一個不存在就重新下載 json 檔 if (!localStorage.hasOwnProperty("LastUpdata") || !localStorage.hasOwnProperty("topbar") || !localStorage.hasOwnProperty("booktypes") || !localStorage.hasOwnProperty("lang") || !localStorage.hasOwnProperty("bookseries") || !localStorage.hasOwnProperty("booktags")) { // 缺少 gtd(true); } else { // 完整 TimeD = (nowTime - localStorage.getItem("LastUpdata")) / 1000; Daily = Daily * 24 * 3600; if (TimeD > Daily) { // 資訊完整 但 達到資料更新時間 gtd(true); } else { topbar = JSON.parse(localStorage.getItem("topbar")); booktypes = JSON.parse(localStorage.getItem("booktypes")); lang = JSON.parse(localStorage.getItem("lang")); bookseries = JSON.parse(localStorage.getItem("bookseries")); booktags = JSON.parse(localStorage.getItem("booktags")); _TopBottom(); } } function gtd(autoUpdata) { localStorage.setItem("LastUpdata", nowTime); fetch(TranslatioDataURL + "?_=" + nowTime, {cache: "no-cache"}) .then(r => r.json()) .then(data => { localStorage.setItem("topbar", JSON.stringify(data.topbar)); localStorage.setItem("booktypes", JSON.stringify(data.booktypes)); localStorage.setItem("lang", JSON.stringify(data.lang)); localStorage.setItem("bookseries", JSON.stringify(data.bookseries)); localStorage.setItem("booktags", JSON.stringify(data.booktags)); topbar = JSON.parse(localStorage.getItem("topbar")); booktypes = JSON.parse(localStorage.getItem("booktypes")); lang = JSON.parse(localStorage.getItem("lang")); bookseries = JSON.parse(localStorage.getItem("bookseries")); booktags = JSON.parse(localStorage.getItem("booktags")); localStorage.setItem("nowSeriesNum", Object.keys(bookseries).length); localStorage.setItem("nowTagsNum", Object.keys(booktags).length); if (autoUpdata) { console.log("資料更新成功"); _TopBottom(); } else { console.log("手動資料更新成功"); $(".navbar nav").append("<div id=\"Notice\"><span>翻譯資料更新成功</span></div><style>#Notice{background-color:rgba(204, 255, 255, 0.9);border-radius:10px;border-top-right-radius:0;border-top-left-radius:0;position:fixed;top:-50px;left:50%;transform:translate(-50%,0);animation:Notice 1s linear}#Notice span{color:#666;display:block;font-weight:bold;margin:10px 63px}@keyframes Notice {0%{top:-50px}35%{top:0}85%{top:0}100%{top:-50px}}</style>"); } }) .catch(e => { console.log("資料取得失敗"); $(".navbar nav").append("<div id=\"Notice\"><span>資料取得失敗</span></div><style>#Notice{background-color:rgba(255, 204, 204, 0.9);border-radius:10px;border-top-right-radius:0;border-top-left-radius:0;position:fixed;top:-50px;left:50%;transform:translate(-50%,0);animation:Notice 2s linear}#Notice span{color:#666;display:block;font-weight:bold;margin:10px 63px}@keyframes Notice {0%{top:-50px}35%{top:0}85%{top:0}100%{top:-50px}}</style>"); throw new Error(e); }); } // 變數 LoadingStatus 0 為正在載入 // 1 為載入完成 // let LoadingStatus = 0; // 是否在"全部系列" let inallsatc = false; // WaitLoad() 等待載入 function WaitLoad() { const loader_content = $("#loader-content"); const gallery_content = $(".gallery-content"); if (loader_content.length == 1 || gallery_content.children().length === 0) { if (loader_content.attr("style") == "display: none;" && gallery_content.children().length > 0) { // 這是給搜尋頁面用的 window.setTimeout(()=>{RunTranslation();}, 150); } else { Timeout(); } } else { window.setTimeout(()=>{RunTranslation();}, 200); } } // Timeout() // 正規表達式 /all(tags|artists|series|characters)|reader/ (在字串中搜索"all"、"reader"字串) // 若 hitomi.la 為"全部"和"閱讀"頁面則一百五十毫秒後呼叫 RunTranslation() // 若是則二百五十毫秒後呼叫 WaitLoad() function Timeout() { // 變數 regex 用來儲存正規表示式 const regex = /all(tags|artists|series|characters)|reader/; if (url.match(regex)) { window.setTimeout(()=>{RunTranslation()}, 150); } else { window.setTimeout(()=>{WaitLoad()}, 250); } } // RunTranslation() // 依序呼叫 _ModifyCSS() _ADRemove() _HotKey() let YouPosition; function RunTranslation() { document.querySelector(".navbar") .insertAdjacentHTML("beforeend","<a id=\"TIMER\" style=\"color: rgb(255, 255, 255);font-weight: bold;\"></a>"); YouPosition = url.split("\/")[1].split(/\-|\./); switch (YouPosition[0]) { case "manga": case "anime": case "doujinshi": case "gamecg": case "cg": case "galleries": { console.log("========= 畫廊資訊區 ========="); setTimeout(() => { _TranslationH3(); document.querySelectorAll(".tags")[1].parentElement.classList.add("relatedtags"); _TranslatioGalleries(); _TranslatioGalleriesInfo(); }, 50); break; } case "reader": { console.log("========= 畫廊閱讀區 ========="); setTimeout(() => { _TranslationReader(); }, 10); break; } case "alltags": { console.log("========= 全部-標籤 ========="); _TranslationAll(); break; } case "allartists": { console.log("========= 全部-畫家 ========="); _TranslationAll(); break; } case "allseries": { console.log("========= 全部-系列 ========="); _TranslationAll(); _TranslationAllSeries(); break; } case "allcharacters": { console.log("========= 全部-角色 ========="); _TranslationAll(); break; } case "search": { console.log("========= 搜索區 ========="); setTimeout(() => { _TranslationSearchH3(); _TranslatioGalleries(); _TranslationSearch(); _HotKey(); }, 10); break; } default: { console.log("========= ♥♥♥♥♥ ========="); setTimeout(() => { _TranslationH3(); _TranslationOrderBy(); _TranslatioGalleries(); }, 10); } } if (url.search("reader") < 0) _ModifyCSS(); _ADRemove(); if (url.search("search") < 0) _HotKey(); localStorage.setItem("hitomi.la_zh-TW", "success"); } function _TopBottom() { _TranslationTopInfo(); if (url.search("reader") < 0) { const GreasyForkIcon = "" const NeocitiesIcon = "" $(".container").append("<style>div#lang-drop{width:135px;padding-top:13px;}ul#lang-list a{display:block}</style>"); $(".navbar>nav>ul").append("<li id=\"cht_help\"><a title=\"hitomi.la_zh-TW\">腳本問題 <img src=\"//ltn.hitomi.la/down-arrow.png\"></a><div id=\"cht_help_drop\"><ul id=\"cht_help_list\"><li><span>系列翻譯數:" + localStorage.getItem("nowSeriesNum") + "</span></li><li><span>標籤翻譯數:" + localStorage.getItem("nowTagsNum") + "</span></li><li><a id=\"update\">手動更新數據</a></li><li><a href=\"https://goo.gl/iurbA6\" target=\"_blank\">中文化問題</a></li><li><hr></li><li><a href=\"https://greasyfork.org/zh-TW/scripts/23864-hitomi-la-zh-tw\" target=\"_blank\"><img src='" + GreasyForkIcon + "' alt=\"greasyfork icon\" >Greasy Fork</a></li><li><a href=\"https://zxc129567142.neocities.org/hitomi_la_zh_tw/index.html\" target=\"_blank\"><img src='" + NeocitiesIcon + "'>Neocities</a></li></ul></div></li>"); $(".navbar>nav").append("<style>#cht_help_drop{display:none;position:absolute;margin:0px;padding:0px 15px;padding-top:13px;z-index:99999;background-color:#29313d;left:0px;right:0px;max-height:500px;width:155px;}#cht_help:hover #cht_help_drop{display:block;}#cht_help_list li{color:#aaa;display:block;position:relative;margin-bottom:10px;}#cht_help_list a,#cht_help_list span{color:inherit;display:block;padding:0px;text-decoration:none;text-transform:none;font-weight:normal;}#cht_help_list a{cursor:pointer;}#cht_help_list a:hover{color:#fff;font-weight:bold;}#cht_help_list span{cursor:default;}#cht_help_list img{vertical-align:middle;margin-right:5px;width:20px;}#cht_help_list svg{margin-right:5px;}</style>"); } _TranslationBottomDonate(); $("#update").one('click', () => { gtd(false); }); Timeout(); } //翻譯上方的導覽列 function _TranslationTopInfo() { //頂部分類類型 $(".navbar a").each((i, v) => { tEng.topbar(v); }); //頂部語言 const lang = document.querySelector("li#lang>a") if (lang){ if (lang.textContent.trim() === "language") lang.innerHTML = "語言 <img src='//ltn.hitomi.la/down-arrow.png'>"; } const interval = setInterval(() => { const lang_list = document.querySelectorAll("#lang-list a"); if (lang_list.length > 1) { clearInterval(interval); for (const item of lang_list) { // console.log(item); tEng.topbarLang(item); } } }, 500 ) //頂部搜尋 if ($(".header-table").length > 0) { $("button#search-button").text("搜尋"); let search_hint = "你可以使用組合條件 \"female:yuri -female:futanari\",此範例會尋找含有 \"yuri\" 但不含 \"futanari\"。" search_hint += "\n當要輸入帶有空白的標籤使用 \"_\" 字符。" search_hint += "\n更多範例:" search_hint += "\n\"series:kantai_collection type:doujinshi female:big_breasts\",會尋找含有 \"系列:艦隊收藏\"、\"類型:同人誌\"、\"巨乳 ♀\" " search_hint += "\n\"type:artistcg female:milf -male:yaoi language:chinese\",會尋找含有 \"類型:美術 CG\"、\"熟女 ♀\"、\"語言:中文\" 但不包含 \"男同(BL) ♂\" " search_hint += "\n\"artist:andou_tomoya -type:gamecg series:love_live\",會尋找含有 \"畫家:Andou Tomoya\"、\"系列:Love Live\" 但不包含 \"類型:遊戲 CG\" " $(".search-input#search").attr("title", search_hint); } } //翻譯畫廊相關 function _TranslatioGalleries() { //分類 const cata = { "Series": "系列", "Type": "類型", "Language": "語言", "Tags": "標籤", "Group": "群組", "Characters": "角色", } document.querySelectorAll("tr td:nth-of-type(1)").forEach(v => { const text = v.textContent switch (text) { case "Series": if (v.nextElementSibling.firstElementChild) v.nextElementSibling.firstElementChild.className = "comma-list"; case "Type": case "Language": case "Tags": case "Group": case "Characters": v.title = text; v.textContent = cata[text]; break; default: { console.log("例外 分類: " + text); } } }); //語言 document.querySelectorAll("tr:nth-of-type(3) td:nth-of-type(2) a") .forEach(item => { tEng.lang(item); }) //類型 document.querySelectorAll("tr:nth-child(2) td:nth-child(2) a") .forEach(item => { tEng.types(item); }) //系列 document.querySelectorAll("table .comma-list a") .forEach(item => { tEng.series(item); }) //標籤 document.querySelectorAll(".relatedtags a") .forEach(item => { tEng.tags(item); }) //當群組、系列、語言為"N/A" document.querySelectorAll("tr:not(:last-of-type) td:nth-of-type(2)") .forEach(item => { tEng.tocht(item, "N/A", "無"); }) //當作者名為"N/A" document.querySelectorAll("div.artist-list") .forEach(item => { tEng.tocht(item, "N/A", "無"); }) } //翻譯畫廊資訊頁面 function _TranslatioGalleriesInfo() { //資訊頁面作者名為"N/A" document.querySelectorAll("h2") .forEach(item => { tEng.tocht(item, "N/A", "無"); }) //資訊頁面 document.querySelectorAll(".cover-column h1").forEach( item => { switch (item.textContent) { case "Download": item.textContent = "下載" break; case "Read Online": item.textContent = "線上閱讀" break; default: break; } }); } //翻譯h3標題 function _TranslationH3() { //區塊h3標題 const h3 = document.querySelector("div.list-title h3") switch (h3.textContent) { case "Recently Added": { tEng.tocht(h3, "Recently Added", "最近更新"); break; } case "Popular": { tEng.tocht(h3, "Popular", "熱門度"); break; } case "Related Galleries": { tEng.tocht(h3, "Related Galleries", "相關畫廊"); break; } default: { console.log(h3.textContent); } } } //翻譯搜尋頁h3標題 function _TranslationSearchH3() { //區塊h3標題 const h3 = $("div.list-title h3"); const engTxt = h3.text(); const chtTxt = engTxt.replace("Results", "個結果"); h3.attr("title", engTxt).text(chtTxt); } //翻譯搜尋頁 function _TranslationSearch() { const pag_top = $(".page-top a") if (pag_top.length === 0) { const search_message = document.querySelector(".gallery-content .search-message"); if (search_message.textContent == "No results") search_message.textContent = "無結果"; return; } pag_top.one("click", () => { setTimeout(function _Search() { const loader_content = document.getElementById("loader-content"); if (!loader_content) return; if (loader_content.style.display == "none" && $(".gallery-content").children().length > 0) { _TranslatioGalleries(); _ModifyCSS(); _HotKey(); _TranslationSearch(); } else { setTimeout(() => { _Search() }, 150); } }, 50); }); } //翻譯"全部"頁面 function _TranslationAll() { //"全部"頁面大標題 let count = 0; let satc = [ ["tags", "artists", "series", "characters"], ["標籤", "畫家", "系列", "角色"] ], atoz = ["123", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"], allh3 = $("div.list-title h3"); inallsatc = true; for (let S = 0; S < satc[0].length; S++) { if (allh3.text().match(satc[0][S]) == satc[0][S]) { for (let A = 0; A < atoz.length; A++) { if (allh3.text().substr(-1) == atoz[A].substr(-1) && allh3.text().substr(0, 3) === "All") { allh3.text("全部字首 " + atoz[A] + " 的" + satc[1][S]); count++ } } } } console.log(count); } //翻譯"全部"系列 function _TranslationAllSeries() { //"全部"系列 const ul_post = document.querySelectorAll("ul.posts a") if (ul_post.length > 0 && url.search("allseries") > 0) { ul_post.forEach(item => { tEng.series(item); }); } } //翻譯閱讀頁面 function _TranslationReader() { document.querySelectorAll(".brand") .forEach(item => { tEng.tocht(item, "Gallery Info", "畫廊資訊"); }); document.querySelectorAll(".navbar-nav a") .forEach((item)=>{ const itemText = item.textContent.trim() const itemID = item.id if (itemText === "Next") item.innerHTML = "<i class='icon-chevron-left icon-white'></i>下一頁"; if (itemText === "Prev") item.innerHTML = "上一頁<i class='icon-chevron-right icon-whitee'></i>"; if (itemText === "Fullscreen") item.innerHTML = "<i class='icon-fullscreen icon-white'></i>全螢幕"; if (itemText === "Full Spread") item.innerHTML = "<i class='icon-pause icon-white'></i>全頁"; if (itemText === "Single Page") item.innerHTML = "<i class='icon-stop icon-white'></i>單頁"; if (itemID === "fitVertical") item.innerHTML = "切合<i class='icon-resize-vertical icon-white'></i>"; if (itemID === "fitHorizontal") item.innerHTML = "切合<i class='icon-resize-horizontal icon-white'></i>"; }); document.querySelectorAll(".input-medium option") .forEach(item => { tEng.tocht(item, item.innerHTML, "第 " + item.value + " 頁"); }); } //翻譯底部官方贊助 function _TranslationBottomDonate() { //底部贊助 const donate = document.querySelector("div.donate"); if (!donate) return; const donateHTML = donate.querySelectorAll(".rss-icon") let cloneRSS = ""; if (donateHTML.length > 0) cloneRSS = donate.innerHTML.replace(donate.textContent, ""); if (donate.innerHTML.match("Donate BTC")) donate.innerHTML = cloneRSS + donate.textContent.replace("Donate BTC","贊助 BTC"); } //翻譯排序方式 function _TranslationOrderBy() { const header_option = document.querySelectorAll("div.header-sort-select option") header_option.forEach(itme => { tEng.tocht(itme, "Order by:", "排序方式"); tEng.tocht(itme, "Date Added", "日期"); tEng.tocht(itme, "Popularity", "熱門度"); }); } //修改CSS function _ModifyCSS() { const container = $(".container") container.append( inallsatc? "<style>h3{margin-top:5px;margin-bottom:5px;padding-left:0px;}div.top-content{padding-top:20px}.page-content ul{color:#d47972}</style>" : "<style>h3{margin-bottom:5px;padding-left:80px;}div.top-content{padding-top:15px}</style>" ); $("div.gallery-info").find("tr").children("td:first-child").css("width", "50px"); const djContent = document.querySelectorAll("div.dj-content") for (const content of djContent) { } $("div.dj-content").each((i, v) => { const item = $(v) const item_a = item.find("a").last() if (item.parent().find("h1 a").attr("href") === item_a.attr("href")) { item_a.css("display", "none"); } item.find("li.hidden-list-item").removeClass("hidden-list-item"); item.find("tr td:first-child").css("width", "50px"); }); } //額外-廣告 function _ADRemove() { const els = document.querySelectorAll("div[class*='hitomi'],div[id*='hitomi'],div[style*='z-index'],div[style*='position'],iframe") for (const el of els) el.remove(); } // 額外-熱鍵 // 參考:Danbooru(https://danbooru.donmai.us/static/keyboard_shortcuts) // 重複執行 function _HotKey() { console.log("[_HotKey Init]"); let page = $("html"), pagClass = "", pageIndex = 0, First_page = 1, End_page = 0, Scroll_Length = 50, Break_HotKey = false; let getEl, findEl, Next_pageIndex, Previous_pageIndex; // 搜尋頁面有問題 // 搜尋頁面 : 其他頁面 pagClass = (url.search("search") > 0) ? ".page-top" : ".page-container" const pag = document.querySelector(pagClass); if (pag) { getEl = pag.querySelectorAll("li"); findEl = [...getEl].filter((b) => b.childElementCount === 0 && b.textContent.search(/\d+/) === 0); pageIndex = parseInt(findEl[0].textContent); End_page = parseInt(pag.querySelector("li:last-child").textContent); localStorage.setItem("pageIndex", pageIndex); if(pageIndex < End_page) pag.querySelector(`a[href$='${pageIndex + 1}']`).classList.add("Next_pageIndex"); if(pageIndex > First_page) pag.querySelector(`a[href$='${(pageIndex - 1 === 1 && pagClass === ".page-container") ? decodeURI(location.pathname) : `${pageIndex - 1}`}']`).classList.add("Previous_pageIndex"); Next_pageIndex = pag.querySelector("a.Next_pageIndex"); Previous_pageIndex = pag.querySelector("a.Previous_pageIndex"); } document.body.onkeyup = function (e) { let _pI = parseInt(localStorage.getItem("pageIndex")) if (document.querySelectorAll("#query-input:focus").length > 0) Break_HotKey = true; switch (e.key) { case "ContextMenu": case "Control": case "Shift": case "Alt": case "Tab": case "Meta": Break_HotKey = true; return false; case "D": case "d": case "ArrowRight": //下一頁 if (End_page > _pI && !Break_HotKey && Next_pageIndex) { Next_pageIndex.click(); } Break_HotKey = false; break; case "A": case "a": case "ArrowLeft": //上一頁 if (First_page < _pI && !Break_HotKey && Previous_pageIndex) { Previous_pageIndex.click(); } Break_HotKey = false; break; case "W": case "w": case "S": case "s": Scroll_Length = 50; Break_HotKey = false; break; case "H": case "h": //回首頁 if (!Break_HotKey) { $("div#logo a")[0].click(); } Break_HotKey = false; break; case "Q": case "q": //搜索 if (!url.match("(\/reader\/)") && !Break_HotKey) { page.stop().animate({ scrollTop: 0, }, 200, "linear", () => { $("#query-input").focus(); }); } Break_HotKey = false; break; default: Break_HotKey = false; } } document.body.onkeydown = function (e) { if (document.querySelectorAll("#query-input:focus").length > 0) Break_HotKey = true; switch (e.key) { case "ContextMenu": case "Control": case "Shift": case "Alt": case "Tab": case "Meta": Break_HotKey = true; return false; case "W": case "w": //向上滾動 if (page.scrollTop() > 0 && !Break_HotKey) { page.stop().animate({ scrollTop: page.scrollTop() - Scroll_Length, }, 100, "linear"); Scroll_Length += 5; } else { //網頁到頂 break; } Break_HotKey = false; break; case "S": case "s": //向下滾動 if (page.scrollTop() + $(window).height() < page.outerHeight() && !Break_HotKey) { page.stop().animate({ scrollTop: page.scrollTop() + Scroll_Length, }, 100, "linear"); Scroll_Length += 5; } else { //網頁到底 break; } Break_HotKey = false; break; default: Break_HotKey = false; } }; } })();