🎉 欢迎访问GreasyFork.Org 镜像站!本镜像站由公众号【爱吃馍】搭建,用于分享脚本。联系邮箱📮

Greasy fork 爱吃馍镜像

B站 周姐

B站首页看周姐!

As of 2021-11-26. See the latest version.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

🚀 安装遇到问题?关注公众号获取帮助

公众号二维码

扫码关注【爱吃馍】

回复【脚本】获取最新教程和防失联地址

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

🚀 安装遇到问题?关注公众号获取帮助

公众号二维码

扫码关注【爱吃馍】

回复【脚本】获取最新教程和防失联地址

// ==UserScript==
// @name         B站 周姐
// @namespace    https://space.bilibili.com/15516023
// @version      1.4
// @description  B站首页看周姐!
// @author       You
// @match        https://www.bilibili.com/
// @icon         https://www.google.com/s2/favicons?domain=bilibili.com
// @grant        GM_addStyle
// @license      MIT
// ==/UserScript==


;(function () {
  'use strict'
  GM_addStyle(`
    #bili_zhoushuyi .popover-video-card {
      display: none;
    }
    #bili_zhoushuyi a:hover+.popover-video-card {
      display: block;
    }
  `)
  const TITLE = '周姐'
  const KEY_WORDS = '周淑怡'
  const ICON =
  ''
  
  let currentPage = 1
  let page = 0
  let videoList = []

  async function getDetail(bvid) {
    let res = await fetch(
      `https://api.bilibili.com/x/web-interface/archive/stat?bvid=${bvid}`,
    )
    return (await res.json()).data
  }

  async function getNewVideo() {
    let res = await fetch(
      `https://api.bilibili.com/x/web-interface/search/type?context=&order=pubdate&keyword=${KEY_WORDS}&search_type=video&page=${currentPage++}`,
    )
    videoList = videoList.concat((await res.json()).data.result)
  }

  async function getHotVideo() {
    let res = await fetch(
      `https://api.bilibili.com/x/web-interface/web/channel/multiple/list?channel_id=780447&sort_type=hot&offset=&page_size=8`,
    )
    return (await res.json()).data.list[0].items
  }

  function bigNumber(num) {
    return num > 10000 ? `${(num / 10000).toFixed(2)}万` : num
  }

  function s2d(string) {
    return new DOMParser().parseFromString(string, 'text/html').body.childNodes[0]
  }

  async function refresh () {
    page++
    if (videoList.length < page * 8 + 8) {
      await getNewVideo()
    }
    drawVideos()
  }

  function timeFormat(time) {
    let res = []
    let [s = 0, m = 0] = time.split(':').reverse()

    res.unshift(String(s).padStart(2, '0'))
    res.unshift(String(m % 60).padStart(2, '0'))
    let h = Math.floor(m / 60)
    if (h) {
      res.unshift(String(h % 60).padStart(2, '0'))
    }
    return res.join(':')
  }

  function drawVideos() {
    const VIDEO_DOM = document.querySelector('#bili_zhoushuyi .zone-list-box')
    VIDEO_DOM.innerHTML = ''
    
    videoList.slice(page*8, page*8+8).forEach((item) => {
      let title = item.title.replace(/<em class="keyword">(.*?)<\/em>/g, '$1')
      let DOM = s2d(`
        <div class="video-card-common">
          <div class="card-pic card-pic-hover"><a href="//www.bilibili.com/video/${item.bvid}" target="_blank"><img
              src="${item.pic}"
              alt="">
            <div class="count">
              <div class="left"><span><i class="bilifont bili-icon_shipin_bofangshu"></i>
                  ${item.play}
                </span><span><i class="bilifont bili-icon_shipin_dianzanshu"></i>${item.favorites}</span></div>
              <div class="right"><span>${timeFormat(item.duration)}</span></div>
            </div><i class="crown"></i>
          </a>
          <div class="watch-later-video van-watchlater black"><span class="wl-tips" style="display: none;"></span>
          </div>
        </div><a href="//www.bilibili.com/video/${item.bvid}" target="_blank" title="${title}"
          class="title">
          ${title}
        </a><a href="//space.bilibili.com/${item.mid}/" target="_blank" class="up"><i
            class="bilifont bili-icon_xinxi_UPzhu"></i>${item.author}
        </a>
      </div>`)
      VIDEO_DOM.append(DOM)
    })
  }

  let zhoujieDOM = `
  <div id="bili_zhoushuyi">
    <div class="space-between report-wrap-module report-scroll-module" id="bili_report_douga" scrollshow="true">
      <div class="card-list">
        <header class="storey-title">
          <div class="l-con"> <img class="svg-icon" src="${ICON}" /> <a
              href="https://search.bilibili.com/all?keyword=${KEY_WORDS}" target="_blank" class="name">${TITLE}</a></div>
          <div class="exchange-btn">
            <div class="btn btn-change zhoujie-refresh"><i class="bilifont bili-icon_caozuo_huanyihuan"></i> 换一换 </div><a
              href="https://search.bilibili.com/all?keyword=${KEY_WORDS}&order=pubdate" target="_blank" class="btn more">
              更多 <i class="bilifont bili-icon_caozuo_qianwang"></i></a>
          </div>
        </header>
        <div class="zone-list-box"> </div>
      </div>
      <div class="rank-list">
        <header class="rank-header"><span class="name">排行榜</span><a
            href="https://www.bilibili.com/v/channel/780447?tab=multiple" target="_blank" class="more">更多<i
              class="bilifont bili-icon_caozuo_qianwang"></i></a></header>
      </div>
    </div>
  </div>`

  window.addEventListener(
    'load',
    async function () {
      let content = document.querySelector('.first-screen')
      let anchor = document.querySelector('#reportFirst2')
      let init = s2d(zhoujieDOM)
        
      // 插入初始模版
      content.insertBefore(init, anchor)

      document.querySelector('.zhoujie-refresh').addEventListener('click', refresh)
      
      const RANK_DOM = document.querySelector('#bili_zhoushuyi .rank-list')
      
      // 插入最新视频
      await getNewVideo()
      drawVideos()
      
    
      // 插入热门视频
      let rankList = await getHotVideo()
      let firstDetail = await getDetail(rankList[0].bvid)
      let firstTitle = rankList[0].name.replace(/<em class="keyword">(.*?)<\/em>/g, '$1')
      let first = `
      <div class="rank-wrap"><span class="number on">1</span>
        <div class="preview">
          <div class="pic">
            <a href="//www.bilibili.com/video/${rankList[0].bvid}" target="_blank" class="link">
              <img src="${rankList[0].cover}" alt="${firstTitle}">
            </a>
            <div class="watch-later-video van-watchlater black"><span class="wl-tips" style="display: none;"></span>
            </div>
          </div>
          <div class="txt"><a href="//www.bilibili.com/video/${
            rankList[0].bvid
          }" target="_blank" class="link">
              <p title="${firstTitle}">${firstTitle}</p>
            </a><span>播放次数:${bigNumber(firstDetail.view)}</span></div>
        </div>
        <div class="popover-video-card pvc" style="display: none;">
          <div class="content"><img src="${rankList[0].cover}" alt="">
            <div class="info">
              <p class="f-title">${firstTitle}</p>
              <p class="subtitle"><span class="name">${rankList[0].author_name }</span>
                <span class="point">·</span><span class="time">2021-11-22</span></p>
            </div>
          </div>
          <div class="count">
            <ul>
              <li><i class="bilifont bili-icon_shipin_bofangshu"></i><span>${bigNumber( firstDetail.view )}</span></li>
              <li><i class="bilifont bili-icon_shipin_danmushu"></i><span>${bigNumber( firstDetail.danmaku )}</span></li>
              <li><i class="bilifont bili-icon_shipin_shoucangshu"></i><span>${bigNumber( firstDetail.favorite )}</span></li>
              <li><i class="bilifont bili-icon_shipin_yingbishu"></i><span>${bigNumber( firstDetail.coin )}</span></li>
            </ul>
          </div>
        </div>
      </div>
      `
      RANK_DOM.append(s2d(first))

      rankList.slice(1, 10).forEach((item, index) => {
        let title = item.name.replace(/<em class="keyword">(.*?)<\/em>/g, '$1')
        let DOM = s2d(`
        <div class="rank-wrap"><span class="number ${index < 2 && 'on'}">${index + 2}</span>
          <a href="//www.bilibili.com/video/${item.bvid}" target="_blank" class="link">
            <p title="${title}" class="title">${title}</p>
          </a>
          <div class="popover-video-card pvc">
            <div class="content"><img
                src="${item.cover}" alt="">
              <div class="info">
                <p class="f-title">${title}</p>
                <p class="subtitle"><span class="name">${
                  item.author_name
                }</span><span class="point">·</span><span
                    class="time">${timeFormat(item.duration)}</span></p>
              </div>
            </div>
            <div class="count">
              <ul>
                <li><i class="bilifont bili-icon_shipin_bofangshu"></i><span>-</span></li>
                <li><i class="bilifont bili-icon_shipin_danmushu"></i><span>-</span></li>
                <li><i class="bilifont bili-icon_shipin_shoucangshu"></i><span>-</span></li>
                <li><i class="bilifont bili-icon_shipin_yingbishu"></i><span>-</span></li>
              </ul>
            </div>  
          </div>
        </div>`)
        RANK_DOM.append(DOM)
      })
    },
    false,
  )
})()