当前位置: 首页 > wzjs >正文

网站怎么做双机房切换wordpress插件vpn

网站怎么做双机房切换,wordpress插件vpn,常州网警,如何设计自己的网页店铺从零开发一个B站视频数据统计Chrome插件 前言 B站(哔哩哔哩)作为国内最大的弹幕视频网站之一,视频的播放量、点赞、投币、收藏等数据对于内容创作者和数据分析者来说非常重要。本文将带你一步步实现一个Chrome插件,自动统计并展…

从零开发一个B站视频数据统计Chrome插件

前言

B站(哔哩哔哩)作为国内最大的弹幕视频网站之一,视频的播放量、点赞、投币、收藏等数据对于内容创作者和数据分析者来说非常重要。本文将带你一步步实现一个Chrome插件,自动统计并展示B站视频页面的核心数据,并以表格形式美观地呈现。


一、需求分析

目标:

  • 在B站视频页面,自动抓取并统计该视频的播放量、点赞、投币、收藏、分享、转发等数据。
  • 以表格形式展示,包含视频标题,表头清晰,数据一目了然。
  • 支持新版B站页面的DOM结构,保证数据准确。

二、技术选型

  • Chrome扩展开发:基于Manifest V3,使用content script和popup页面。
  • JavaScript:实现数据抓取与页面交互。
  • HTML/CSS:负责弹窗UI和表格美化。
  • DOM选择器:精准定位B站页面各项数据。
  • 调试工具:Chrome开发者工具(F12)辅助定位元素。

三、开发流程

1. 插件目录结构

bilibili-stats-extension/
├── manifest.json
├── content.js
├── popup.html
├── popup.js
├── style.css
└── icon.png

2. manifest.json 配置

声明插件基本信息、权限、注入脚本和弹窗页面:

{"manifest_version": 3,"name": "B站视频数据统计","version": "1.0","description": "统计B站视频的播放、点赞、投币、分享、收藏、转发等数据,并以表格展示。","permissions": ["activeTab", "scripting"],"host_permissions": ["https://www.bilibili.com/video/*"],"content_scripts": [{"matches": ["https://www.bilibili.com/video/*"],"js": ["content.js"],"css": ["style.css"]}],"action": {"default_popup": "popup.html","default_icon": "icon.png"},"icons": {"16": "icon.png","48": "icon.png","128": "icon.png"}
}

3. popup.html 设计

  • 添加 <meta charset="UTF-8"> 解决中文乱码。
  • 页面顶部显示主标题。
  • 预留数据展示区域。
<!DOCTYPE html>
<html><head><meta charset="UTF-8"><title>B站视频数据统计</title><style>body { font-family: Arial, sans-serif; min-width: 200px; }table { width: 100%; border-collapse: collapse; }th, td { border: 1px solid #ddd; padding: 6px; }th { background: #f5f5f5; }</style></head><body><h2 style="text-align:center;margin-top:10px;">B站视频数据统计</h2><div id="stats">正在获取数据...</div><script src="popup.js"></script></body>
</html>

4. popup.js 核心逻辑

  • 通过 chrome.scripting.executeScript 在B站页面上下文抓取数据。
  • 精准选择器获取各项数据(如 .view-text.video-like-info.video-toolbar-item-text 等)。
  • 构建表格,标题单独一行,表头为“指标/数值”,数据逐项展示。
function getStatsFromContentScript() {chrome.tabs.query({active: true, currentWindow: true}, function(tabs) {chrome.scripting.executeScript({target: {tabId: tabs[0].id},func: () => {// 获取视频标题let title = document.querySelector('h1[data-v-1b2c6b56], h1.video-title, h1')?.innerText?.trim() || document.title || 'N/A';const getText = (selector) => {const el = document.querySelector(selector);return el ? el.innerText.trim() : 'N/A';};// 选择器需根据实际页面结构调整let play = getText('.view-text');let like = getText('.video-like-info.video-toolbar-item-text');let coin = getText('.video-coin-info.video-toolbar-item-text');let favorite = getText('.video-fav-info.video-toolbar-item-text');let share = getText('.video-share-info-text');let repost = getText('.video-share-info-text'); // B站新版转发与分享合并return {标题: title,播放: play,点赞: like,投币: coin,收藏: favorite,分享: share,转发: repost};}},(results) => {if (results && results[0] && results[0].result) {showStats(results[0].result);} else {showStats({错误: "未获取到数据,请在B站视频页面使用"});}});});
}function showStats(stats) {const table = document.createElement('table');// 标题行if (stats["标题"]) {const titleRow = document.createElement('tr');const titleCell = document.createElement('th');titleCell.colSpan = 2;titleCell.innerText = stats["标题"];titleCell.style.textAlign = 'center';titleCell.style.fontSize = '16px';titleCell.style.background = '#e9e9e9';titleRow.appendChild(titleCell);table.appendChild(titleRow);delete stats["标题"];}// 表头const headerRow = document.createElement('tr');const th1 = document.createElement('th');th1.innerText = '指标';const th2 = document.createElement('th');th2.innerText = '数值';headerRow.appendChild(th1);headerRow.appendChild(th2);table.appendChild(headerRow);// 数据行for (const [key, value] of Object.entries(stats)) {const row = document.createElement('tr');const th = document.createElement('th');th.innerText = key;const td = document.createElement('td');td.innerText = value;row.appendChild(th);row.appendChild(td);table.appendChild(row);}const container = document.getElementById('stats');container.innerHTML = '';container.appendChild(table);
}document.addEventListener('DOMContentLoaded', function() {getStatsFromContentScript();
});

5. 选择器的确定与调试

  • 通过 Chrome F12 检查元素,右键复制 selector,确保选择器准确。
  • 例如:
    • 播放量:.view-text
    • 点赞:.video-like-info.video-toolbar-item-text
    • 投币:.video-coin-info.video-toolbar-item-text
    • 收藏:.video-fav-info.video-toolbar-item-text
    • 分享/转发:.video-share-info-text

6. 兼容性与健壮性

  • 若数据未能获取,显示“N/A”。
  • 选择器随B站页面更新需适时调整。
  • 插件支持新版B站视频页面。

四、效果展示

在这里插入图片描述

五、总结与展望

本文完整介绍了如何开发一个B站视频数据统计Chrome插件,从需求分析、技术选型、开发流程到选择器调试与UI优化。
该插件可帮助内容创作者、数据分析师快速获取视频核心数据。后续可扩展为批量采集、导出数据、支持更多平台等功能。


如果你也想开发类似插件,欢迎参考本教程并根据实际需求灵活调整!

http://www.dtcms.com/wzjs/819171.html

相关文章:

  • 怎么做淘宝联盟网站装饰设计有限公司经营范围
  • 一个网站的tdk是指网站的广西建设部投诉网站
  • 阿里云一个域名做两个网站微信管理系统在哪里
  • 哪里有免费的网站推广软件电商网站优化方案
  • 湖北企业响应式网站建设价位番禺市桥网站建设公司
  • 印度电商平台网站建设策划如何自建一个便宜的网站
  • 网站制作的主要流程短网址生成器在线
  • 微网站模板制作教程企业网站的建立多少钱
  • 不写编程可以做网站建设中国网通做网站
  • 枣庄学习建设网站培训微问数据平台入口
  • 东营网站建设哪家好下载网站php源码
  • 网站建设营销企业品牌型网站
  • 可以看设计的网站有哪些深圳系统网站开发
  • 服务器购买网站美食网站设计欣赏
  • 免注册个人网站制作东营住房和城乡建设部网站
  • iss里面的默认网站开启不了提示服务器无响应.怎么开启网站解析后显示建设中
  • 做网站想注册商标是哪一类wordpress中国主题
  • 聊城网站建设设计实力公司wordpress粘贴关键词
  • 网站搭建dns有用吗使用wordpress创建企业官网
  • 个人什么取消网站备案网站用ps下拉效果怎么做
  • 旅行社网站的建设开题报告wordpress 移植
  • 苏州木渎做网站网站模块分类
  • wordpress长文档分页苏宁网站优化与推广
  • 建设银行行号网站查询是什么意思做网站服务器权限设置
  • 网站设计专业建站公司电商网站 投诉
  • 百度一下你知道白山网站seo
  • 窗帘网站建设策划书道客巴巴长沙建网站制作公司
  • 社交媒体营销wordpress网站好优化吗
  • 为自己网站建设世纪购网站开发招聘
  • 网站制作的市场前景做挂件的网站