Greasy Fork is available in English.
直接在动态首页展示所有的正在直播名单,而不是默认10个
// ==UserScript== // @name B站动态首页展示所有正在直播列表 // @namespace http://tampermonkey.net/ // @version 0.2.4 // @description 直接在动态首页展示所有的正在直播名单,而不是默认10个 // @author tuntun // @match https://t.bilibili.com/* // @icon https://www.google.com/s2/favicons?domain=bilibili.com // @grant GM_addStyle // @license MIT // ==/UserScript== (function () { 'use strict'; GM_addStyle(` .bili-dyn-live-users { max-height: calc(100vh - 276px); overflow-y: overlay; } .bili-dyn-live-users::-webkit-scrollbar { width: 10px; /*滚动条的宽度*/ height: 8px; /*滚动条的高度*/ opacity: 0; } .bili-dyn-live-users::-webkit-scrollbar-track-piece { background-color: #fff; /*滚动条的背景颜色*/ -webkit-border-radius: 0; /*滚动条的圆角宽度*/ opacity: 0; } .bili-dyn-live-users::-webkit-scrollbar-thumb { height: 50px; background-color: #ccc; -webkit-border-radius: 4px; outline: 2px solid #fff; outline-offset: -2px; border: 2px solid #fff; display: none; } .bili-dyn-live-users::-webkit-scrollbar-thumb:hover { background-color: #9f9f9f; } .bili-dyn-live-users:hover::-webkit-scrollbar-thumb { display: block; } .bili-dyn-live-users::-webkit-scrollbar-track { display: none; } .bili-dyn-live-users::-webkit-scrollbar-track-piece { display: none; } `) const API = { // 封装get方法 Get: async (props) => { const { url: baseUrl, params = {} } = props; let pStr = Object.keys(params).map((key) => { return `${key}=${params[key]}`; }).join('&'); let url = `${baseUrl}${pStr !== '' ? '?' : ''}${pStr}`; try { let res = await fetch(url, { credentials: "include" }); return (await res.json()).data; } catch (error) { console.error('Get Error', error); } }, // 通过关键词获取视频数据 getLiver: async (num = 0) => { try { let params = {}; if (num !== 0) { params = { size: num } } let res = await API.Get({ url: 'https://api.vc.bilibili.com/dynamic_svr/v1/dynamic_svr/w_live_users', params, }); return res; } catch (error) { console.log('getLiver', error); } }, getCard: async (mid) => { try { let res = await API.Get({ url: 'https://api.bilibili.com/x/web-interface/card', params: { mid, photo: 'true', }, }); return res; } catch (error) { console.log('getCard', error); } } } const Tool = { // 大数转万 formatBigNumber: (num) => { return num > 10000 ? `${(num / 10000).toFixed(2)}万` : num }, // 字符串转DOM s2d: (string) => { return new DOMParser().parseFromString(string, 'text/html').body .childNodes[0] }, } const getListItemTemplete = (prop) => { return ` <div class="bili-dyn-live-users__item"> <a href="${prop.link}" target="_blank" style="display: flex"> <div class="bili-dyn-live-users__item__left"> <div class="bili-dyn-live-users__item__face-container"> <div class="bili-dyn-live-users__item__face"> <div class="bili-awesome-img" style="background-image: url(${prop.face.slice(6)}@47w_47h_1c.webp);"> </div> </div> </div> </div> <div class="bili-dyn-live-users__item__right"> <div class="bili-dyn-live-users__item__uname bili-ellipsis"> ${prop.uname} </div> <div class="bili-dyn-live-users__item__title bili-ellipsis"> ${prop.title} </div> </div> </a> </div> ` } const getCardTemplete = async (params) => { const {mid, x, y} = params; let data = await API.getCard(mid); let card = data.card; return ` <div data-v-6c7ff250="" class="userinfo-wrapper" style="top: ${x}px; left: ${y}px"> <div data-v-1b335720="" data-v-6c7ff250="" class="userinfo-content"> <!----> <div data-v-1b335720="" class="bg" style=" background-image: url('${data.space.l_img.slice(5)}@120h.webp'); "></div> <a data-v-1b335720="" href="//space.bilibili.com/${mid}/dynamic" target="_blank" class="face"> <img data-v-1b335720="" src="${card.face.slice(5)}@50w_50h_1c.webp" /> ${card.official_verify.type !== -1 ? `<div data-v-1b335720="" class="verify-box type-${card.official_verify.type}"></div>` : ''} </a> <div data-v-1b335720="" class="info"> <p data-v-1b335720="" class="user"> <a data-v-1b335720="" target="_blank" href="//space.bilibili.com/${mid}/dynamic" class="name ${card.vip.status === 0 ? '' : 'vip'}" ${card.vip.status === 0 ? '' : 'style="color: rgb(251, 114, 153)"'}>${card.name}</a> <!----><a data-v-1b335720="" target="_blank" href="//www.bilibili.com/html/help.html#k_5"><img data-v-1b335720="" src="" class="level" /></a> <span data-v-1b335720="" class="vip-label" style=" background-color: rgb(251, 114, 153); color: rgb(255, 255, 255); "><span data-v-1b335720="" class="label-size">年度大会员</span></span> </p> <p data-v-1b335720="" class="social"> <a data-v-1b335720="" href="//space.bilibili.com/7706705/fans/follow" target="_blank"><span data-v-1b335720="" class="follow">281</span><span data-v-1b335720="" class="label">关注</span></a><a data-v-1b335720="" href="//space.bilibili.com/7706705/fans/fans" target="_blank"><span data-v-1b335720="" class="fans">48.5万</span><span data-v-1b335720="" class="label">粉丝</span></a><span data-v-1b335720=""><span data-v-1b335720="" class="like">202.3万</span><span data-v-1b335720="" class="label">获赞</span></span> </p> <p data-v-1b335720="" class="verify-desc"> <i data-v-1b335720="" class="verify-icon type--0"></i><span data-v-1b335720="">bilibili个人认证:bilibili 直播高能主播</span> </p> <p data-v-1b335720="" class="sign"> ${card.sign} </p> </div> <div data-v-1b335720="" class="btn-box"> <a data-v-1b335720="" class="like liked"><span data-v-1b335720="">已关注</span></a><a data-v-1b335720="" href="//message.bilibili.com/#whisper/mid7706705" target="_blank" class="message">发消息</a> </div> </div> </div> ` } const init = async (isReflash = false) => { let firstGet = await API.getLiver(); let liverNum = firstGet.count; if (isReflash || liverNum > 10) { let liveUpListDom = document.querySelector('.bili-dyn-live-users__body'); if (liveUpListDom) { liveUpListDom.innerHTML = ''; let allLiver = await API.getLiver(liverNum); // let addLiverItem = allLiver.items.slice(10); allLiver.items.forEach(item => { if (liveUpListDom !== null) { liveUpListDom.appendChild(Tool.s2d(getListItemTemplete(item))); } }); document.querySelector('.bili-dyn-live-users__title span').innerHTML = `(${allLiver.items.length})` } } } const addRefleshBtn = () => { const header = document.querySelector('.bili-dyn-live-users__header'); const more = document.querySelector('.bili-dyn-live-users__more'); const refleshBtn = Tool.s2d(` <button style="background: white; color: #99a2aa; cursor: pointer; border: #99a2aa;font-size: 12px;">刷新</button> `); try { header.insertBefore(refleshBtn, more); refleshBtn.addEventListener('click', async () => { refleshBtn.innerHTML = '正在刷新'; await init(true); refleshBtn.innerHTML = '刷新'; }); refleshBtn.onmouseover = () => { refleshBtn.style.color = '#00a1d6'; } refleshBtn.onmouseout = () => { refleshBtn.style.color = '#99a2aa'; } } catch (error) { console.log(error); } } window.addEventListener( 'load', async () => { await init(); addRefleshBtn(); }, ) })();