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  // @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");