NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name Pixiv-QuickBookmark // @name:zh-CN Pixiv-快捷收藏 // @name:ja Pixiv-クイックブックマーク // @namespace https://github.com/Mehver // @version 2.9 // @description When press the main area of the image, it will add the bookmark instead of jump to the image page. And add a button to jump to the image page. // @description:zh-CN 点击图片主区域,会直接收藏图片,而不是跳转到图片页面。并额外添加一个按钮用于跳转到图片页面。 // @description:ja 画像のメインエリアを押すと、ブックマークが追加され、画像ページにジャンプしなくなります。 さらに、画像ページにジャンプするためのボタンを追加します。 // @author https://github.com/Mehver // @icon data:image/png;base64,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 // @match http*://pixiv.net // @match http*://pixiv.net/* // @match http*://www.pixiv.net // @match http*://www.pixiv.net/* // @license MPL-2.0 // @license^ Mozilla Public License 2.0 // @grant unsafeWindow // @homepageURL https://github.com/SynRGB/Pixiv-QuickBookmark // @contributionURL https://github.com/SynRGB/Pixiv-QuickBookmark // @updateURL https://github.com/SynRGB/Pixiv-QuickBookmark/releases/new // @copyright Copyright © 2022-PRESENT, Mehver (https://github.com/Mehver) // @charset UTF-8 // @run-at document-end // ==/UserScript== let last_run_time = new Date().getTime(); let main = function () { // pixiv.net/users/* 页面下特有的顶部精选图片,唯一内部dom结构不同的 // the top featured images on pixiv.net/users/*, only theses have different internal dom structure let userFeatured_Imgs = document.querySelectorAll('div[radius="8"]'); // 其他所有图片,内部的dom结构都一样 // all other images, the internal dom structure is the same let allOther_Imgs = document.querySelectorAll('div[radius="4"]'); ///////////////////////////////////////////////////////////////////////////////////////// // 遍历 userFeatured_Imgs for (let i = 0; i < userFeatured_Imgs.length; i++) { // let div = userFeatured_Imgs[i].parentNode.parentNode; let div = userFeatured_Imgs[i].parentNode.parentNode.parentNode; let button = div.querySelector('button'); // 避免重复添加 // avoid duplicate modification let added_check = div.querySelector('div[class="Pixiv-QuickBookmark"]'); // filter real img div if (button !== null && added_check === null) { // get the parent div of the button let buttonDiv = button.parentNode; // move button to left side let divWidth = div.clientWidth; buttonDiv.setAttribute('style', ` position: absolute; width: ${divWidth}px; bottom: 0; `); // add the jump page button to right bottom edge let divToAdd_newJumpButton = document.createElement('div'); divToAdd_newJumpButton.setAttribute('class', 'Pixiv-QuickBookmark'); divToAdd_newJumpButton.setAttribute('style', ` content: ''; position: absolute; right: 0; bottom: 0; border: 17px solid #0096FA; border-top-color: transparent; border-left-color: transparent; `); divToAdd_newJumpButton.addEventListener('click', function () { let a = div.querySelector('a'); a.click(); }); div.appendChild(divToAdd_newJumpButton); // modify the jump page area to bookmark button div.querySelector('a').childNodes[0].addEventListener('click', function (e) { e.preventDefault(); button.click(); }); } } ///////////////////////////////////////////////////////////////////////////////////////// // 遍历 allOther_Imgs for (let i = 0; i < allOther_Imgs.length; i++) { let div = allOther_Imgs[i].parentNode.parentNode.parentNode; // use for filter real img div let button = div.querySelector('button'); // 避免重复添加 // avoid duplicate modification let added_check = div.querySelector('div[class="Pixiv-QuickBookmark"]'); // filter real img div if (button !== null && added_check === null) { // get the parent div of the button let buttonInnerDiv = button.parentNode; let buttonOuterDiv = button.parentNode.parentNode; // move button to left side let divWidth = div.clientWidth; buttonOuterDiv.setAttribute('style', ` position: absolute; width: ${divWidth}px; bottom: 0; `); buttonInnerDiv.setAttribute('style', ` position: relative; left: -${divWidth - 32}px; `); // add the jump page button to right bottom edge let divToAdd_newJumpButton = document.createElement('div'); divToAdd_newJumpButton.setAttribute('class', 'Pixiv-QuickBookmark'); divToAdd_newJumpButton.setAttribute('style', ` content: ''; position: absolute; right: 0; bottom: 0; border: 17px solid #0096FA; border-top-color: transparent; border-left-color: transparent; `); divToAdd_newJumpButton.addEventListener('click', function () { let a = div.querySelector('a'); a.click(); }); div.appendChild(divToAdd_newJumpButton); // modify the jump page area to bookmark button div.querySelector('a').childNodes[0].addEventListener('click', function (e) { e.preventDefault(); button.click(); }); } } last_run_time = new Date().getTime(); } // if DOM changed, re-run the script let MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver; let observer = new MutationObserver(function (mutations) { mutations.forEach(function () { // 通过增加时间间隔来避免无限回调 if (new Date().getTime() - last_run_time > 50) { main(); } }); }); observer.observe(document.body, { childList: true, subtree: true }); console.log("Userscript Pixiv-QuickBookmark (Pixiv-快捷收藏) loaded. See more details at https://github.com/SynRGB/Pixiv-QuickBookmark");