您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Expands pixiv comments. Always shows all comments (and replies).
当前为
// ==UserScript== // @name pixiv コメントを展開 // @name:ja pixiv コメントを展開 // @name:en pixiv Comment Expander // @description Expands pixiv comments. Always shows all comments (and replies). // @description:ja コメント (+ 返信) を常に全件表示します。 // @namespace http://userscripts.org/users/347021 // @version 2.4.0 // @match https://www.pixiv.net/member_illust.php?*mode=medium* // @match https://www.pixiv.net/novel/show.php?*id=* // @require https://gf.qytechs.cn/scripts/17895/code/polyfill.js?version=625392 // @require https://gf.qytechs.cn/scripts/19616/code/utilities.js?version=230651 // @require https://gf.qytechs.cn/scripts/17896/code/start-script.js?version=112958 // @license MPL-2.0 // @compatible Edge 非推奨 / Deprecated // @compatible Firefox // @compatible Opera // @compatible Chrome // @grant dummy // @noframes // @run-at document-start // @icon  // @author 100の人 // @homepageURL https://gf.qytechs.cn/scripts/266 // ==/UserScript== /* @iconに、TMZ様のイラストを使わせていただきました。 「iPhoneふうpixivアイコン」/「TMZ」のイラスト [pixiv] <http://www.pixiv.net/member_illust.php?mode=medium&illust_id=8572587> */ (function () { 'use strict'; class CommentExpander { /** * 1回のコメント取得数制限。 * @constant {number} */ static get LIMIT() {return 200;} constructor() { /** * 小説ページなら `true`。 * @access private * @type {boolean} */ this.novel = location.pathname.startsWith('/novel/'); startScript( () => GreasemonkeyUtils.executeOnUnsafeContext(this.changeLimit, [CommentExpander.LIMIT]), parent => parent.localName === 'html', target => target.localName === 'head', () => document.head ); document.addEventListener('DOMContentLoaded', this); } /** * @param {Event} */ handleEvent(event) { event.currentTarget.removeEventListener(event.type, this); this.expandReplies(); } /*globals fetch:true */ /** * ページ側のコンテキストで実行してコメント取得数を変更する関数。 * @param {number} limit */ changeLimit(limit) { let previousId; let offset; fetch = new Proxy(fetch, { apply(fetch, thisArgument, argumentList) { argumentList[0] = new URL(argumentList[0], location); if (argumentList[0].pathname.endsWith('/comments/roots')) { const params = argumentList[0].searchParams; const id = params.get(this.novel ? 'novel_id' : 'illust_id'); if (id !== previousId) { previousId = id; offset = 0; } params.set('offset', offset); params.set('limit', limit); offset += limit; } return Reflect.apply(fetch, thisArgument, argumentList); }, }); } /** * すべての返信を展開します。 * @access private */ async expandReplies() { const listParent = this.novel ? null : await this.getCommentListParent(); const list = this.novel ? await this.getCommentList() : null; new MutationObserver(mutations => { for (const mutation of mutations) { if (mutation.target.localName === 'button' && mutation.target.classList.length === 1) { // 「以前の返信を見る」の展開 mutation.target.click(); } } }).observe(listParent || list, {attributeFilter: ['class'], subtree: true}); if (list) { this.watchAndClickButtons(list); } else { new MutationObserver(mutations => { let list; for (const mutation of mutations) { for (const node of mutation.addedNodes) { if (node.localName === 'ul') { list = node; break; } } } if (list) { this.watchAndClickButtons(list); } }).observe(listParent, {childList: true}); } } /** * 指定された要素の子の追加を監視し、要素内のすべてのボタンを押します。 * @access private * @param {HTMLUListElement} element */ watchAndClickButtons(element) { this.clickButtons(element); new MutationObserver(mutations => { for (const mutation of mutations) { for (const element of mutation.addedNodes) { this.clickButtons(element); } } }).observe(element, {childList: true}); } /** * 指定された要素内のすべてのボタンを押します。 * @access private * @param {(HTMLUListElement|HTMLLIElement)} element */ clickButtons(element) { for (const button of element.getElementsByTagName('button')) { button.click(); } } /** * イラストページのコメントリストの親要素を取得します。 * @access private * @returns {Promise.<HTMLDivtElement>} */ getCommentListParent() { return new Promise(function (resolve) { new MutationObserver(function (mutations, observer) { const node = document.querySelector('figure ~ section:nth-of-type(2) > div > div > div:nth-of-type(2)'); if (!node) { return; } observer.disconnect(); resolve(node); }).observe(document.getElementById('root'), {childList: true, subtree: true}); }); } /** * 小説ページのコメントリスト要素を取得します。 * @access private * @returns {Promise.<HTMLUListElement>} */ getCommentList() { return new Promise(function (resolve) { new MutationObserver(function (mutations, observer) { for (const mutation of mutations) { for (const node of mutation.addedNodes) { if (node.matches('#js-mount-point-comment-module > div > div:nth-of-type(2) > ul')) { observer.disconnect(); resolve(node); return; } } } }).observe(document.getElementById('js-mount-point-comment-module'), {childList: true, subtree: true}); }); } } new CommentExpander(); })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址