您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
在讨论贴中添加一个悬浮窗显示条目信息
当前为
// ==UserScript== // @name bgm-tv-hover-more-info // @name:zh 鼠标指向条目链接时显示更多信息 // @namespace https://trim21.me/ // @description 在讨论贴中添加一个悬浮窗显示条目信息 // @version 0.1.0 // @author Trim21 <[email protected]> // @source https://github.com/Trim21/bgm-tv-hover-info // @supportURL https://github.com/Trim21/bgm-tv-hover-info/issues // @license MIT // @match https://bgm.tv/group/topic/* // @match https://bangumi.tv/group/topic/* // @match https://chii.in/group/topic/* // @match https://bgm.tv/rakuen/topiclist // @require https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js // @run-at document-end // ==/UserScript== /******/ (() => { // webpackBootstrap /******/ "use strict"; var __webpack_exports__ = {}; ;// CONCATENATED MODULE: external "$" const external_$_namespaceObject = $; ;// CONCATENATED MODULE: ./src/index.ts const style = ` <style> .d-block { display: block; } .d-flex { display: flex; } #popup { width: 30em; /*height: 15em;*/ flex: auto; background: white; border: solid 1px black; position: absolute; padding: 0.5em; border-radius: 0.2em; } .tag .name { /*background-color: dodgerblue;*/ /*color: white;*/ } .popup-tags{ display: block; } .tag { border-radius: 0.2em; border: solid 1px gray; padding: 0 0.3em; } .image { padding-right: 2px; } </style> `; function createPopup(subject) { var ref; let rank = ''; if (subject.rating.rank) { rank = `<p class="rateInfo"> <span class="starstop-s"><span class="starlight stars${Math.round(subject.rating.score)}"></span></span> <small class="fade">${subject.rating.score}</small> <span class="tip_j">(${subject.rating.total}人评分)</span> </p>`; } let tags = ''; if (subject.tags.length) { tags = "<div class='popup-tags'>" + subject.tags.sort((a, b)=>b.count - a.count).slice(0, 10).map((value)=>`<span class="tag"><span class="name">${value.name}</span> <small>${value.count}</small></span>`).join('\n'); tags += '</div>'; } return ` <div class="d-flex"> <span class="image d-block"> <img src="${(ref = subject.images) === null || ref === void 0 ? void 0 : ref.small}" class="cover" alt="${subject.name}"> </span> <div class="d-block"> <h3>${subject.name}</h3> <small class="grey">${subject.name_cn}</small> <p class="info tip"> ${subject.summary} </p> </div> </div> ${rank} ${tags} `; } async function main() { console.log(GM.info.script.name); external_$_namespaceObject('head').append(style); external_$_namespaceObject('a').each((i, e)=>{ if (isBangumiSubjectHref(external_$_namespaceObject(e).attr('href'))) { external_$_namespaceObject(e).on('mouseover', hoverHandler).on('mouseleave', leaveHandler); } }); } function isBangumiSubjectHref(s) { if (!(s === null || s === void 0 ? void 0 : s.length)) return false; return /\/subject\/\d+/.test(s) || /https:\/\/bgm.tv\/subject\/\d+/.test(s) || /https:\/\/bangumi.tv\/subject\/\d+/.test(s) || /https:\/\/chii.in\/subject\/\d+/.test(s); } async function leaveHandler() { external_$_namespaceObject('#popup').remove(); console.log('leave'); } async function hoverHandler() { const e = external_$_namespaceObject(this); const href = e.attr('href'); if (!href) { return; } const offset = e.offset() ?? { left: 0, top: 0 }; external_$_namespaceObject('body').append('<div id="popup"> loading </div>'); const popup = external_$_namespaceObject('#popup').css({ left: offset.left, top: offset.top + 40, position: 'absolute', 'z-index': 1000 }); const subjectID = href.split('/').pop(); if (!subjectID) { return; } const res = await fetch(`https://api.bgm.tv/v0/subjects/${subjectID}`); if (res.status > 400) { popup.html('not found'); return; } const data = await res.json(); let html = createPopup(data); if (res.redirected) { html = '条目被合并到此条目' + html; } popup.html(html); } main().catch(console.error); /******/ })() ;
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址