您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Greasy Fork is available in English.
Download pictures from bilibili timeline
当前为
// ==UserScript== // @name Bilibili Download Pictures // @version 0.2 // @description Download pictures from bilibili timeline // @author OWENDSWANG // @match https://t.bilibili.com/* // @grant GM_download // @namespace http://greasyfork.icu/users/738244 // ==/UserScript== (function() { 'use strict'; // Your code here... var notLoaded = true; var cardsTotal = 0; var startIndex = 0; document.body.addEventListener('mouseover', function(event) { if (notLoaded) { // console.log('body'); // console.log(document.querySelectorAll('div.feed-card').length); var feed = document.querySelector('div.feed-card'); if (feed) { // console.log('feed'); feed.addEventListener('mouseover', function(event) { var cards = feed.querySelectorAll('div.card'); // console.log(cards.length); // console.log(cardsTotal); if (notLoaded || cards.length > cardsTotal) { // console.log('cards'); cardsTotal = cards.length - feed.querySelectorAll('div.card > div.skeleton').length; // console.log(cardsTotal); for (var i = startIndex; i < cardsTotal; i++) { // console.log('card-bg-red'); // cards[i].style.backgroundColor = 'red'; if (cards[i].getElementsByClassName('imagesbox').length > 0) { // console.log('added download button'); var buttonBar = cards[i].getElementsByClassName('button-bar')[0]; var buttons = buttonBar.getElementsByClassName('single-button'); buttons[buttons.length - 1].classList.remove('p-rel'); var downloadButton = document.createElement('div'); downloadButton.classList.add('single-button', 'c-pointer', 'p-rel', 'download-button'); downloadButton.style.display = 'inline-block'; downloadButton.style.lineHeight = '48px'; downloadButton.style.width = '92px'; downloadButton.style.fontSize = '12px'; var span = document.createElement('span'); span.classList.add('text-bar'); var icon = document.createElement('i'); icon.style.background = 'center/contain no-repeat'; icon.style.backgroundSize = '15px'; icon.style.backgroundImage = 'url(\'\')'; icon.style.width = '20px'; icon.style.height = '20px'; icon.style.display = 'inline-block'; icon.style.verticalAlign = 'text-top'; icon.style.margin = '0'; icon.style.padding = '0'; icon.style.marginRight = '4px'; icon.style.marginTop = '-2px'; var text = document.createElement('span'); text.classList.add('text-offset'); if (navigator.language == 'zh-CN') { text.textContent = '下载'; } else { text.textContent = 'Download'; } span.appendChild(icon); span.appendChild(text); downloadButton.appendChild(span); buttonBar.appendChild(downloadButton); downloadButton = buttonBar.getElementsByClassName('download-button')[0]; downloadButton.addEventListener('mouseover', function(event) { this.querySelector('span.text-bar').style.color = '#00a1d6'; this.querySelector('i').style.backgroundImage = 'url(\'\')'; // console.log('over'); }); downloadButton.addEventListener('mouseout', function(event) { this.querySelector('span.text-bar').style.color = null; this.querySelector('i').style.backgroundImage = 'url(\'\')'; // console.log('out'); }); downloadButton.addEventListener('click', function(event) { // console.log('click'); var content = this.closest('div.main-content'); var list = content.querySelectorAll('div.img-content'); if (list.length > 0) { for (var j = 0; j < list.length; j++) { var imgUrl = list[j].style.backgroundImage.split(/"|@/)[1]; if (imgUrl.startsWith('//')) { imgUrl = 'https:' + imgUrl; } var imgName = imgUrl.split('/')[imgUrl.split('/').length - 1]; // console.log(imgUrl); // console.log(imgName); GM_download(imgUrl, imgName); } } else { list = content.querySelectorAll('li > img'); if (list.length > 0) { for (var k = 0; k < list.length; k++) { imgUrl = list[k].src.split('@')[0]; if (imgUrl.startsWith('//')) { imgUrl = 'https:' + imgUrl; } imgName = imgUrl.split('/')[imgUrl.split('/').length - 1]; GM_download(imgUrl, imgName); } } else { var singleImg = content.querySelector('div.boost-img-container > img'); imgUrl = singleImg.src.split('@')[0]; imgName = imgUrl.split('/')[imgUrl.split('/').length - 1]; GM_download(imgUrl, imgName); } } }); } startIndex += 1; } notLoaded = false; } }); } } }); })();