浏览器书签还能一键下载B站视频封面?

说在前面

说起浏览器书签,大家下意识都只会想到可以用来收藏的网址吧?那你知不知道浏览器书签还可以用来制作一些很实用的小工具。

有些小功能通过浏览器插件来实现的话有点"杀鸡用牛刀 ",这时候我们就可以用浏览器书签制作一个小工具来实现,比如我们今天要实现的一个功能:B站视频封面下载

页面分析

封面图片链接

首先我们需要先分析一下B站视频页面,直接F12,简单看一眼不难发现,视频的封面就藏在代码之中

我们可以直接获取到这个图片元素的 src

javascript 复制代码
const img = document.querySelector("#wxwork-share-pic").src;

图片最后的 @100w_100h_1c 规定了图片显示的大小规格,我们直接去掉规格说明获取原图

javascript 复制代码
const img = document.querySelector("#wxwork-share-pic").src.split("@")[0];

图片标题

图片链接获取到了,我们想要下载的图片以视频标题命名,所以我们需要获取到视频的标题

还是直接 F12 一键获取

javascript 复制代码
const title = document.querySelector(
  "#viewbox_report > div.video-info-title > div > h1"
).innerText;

图片下载

图片链接和标题我们都拿到了,那就差最后一步:下载图片

直接创建个a标签下载?

javascript 复制代码
const link = document.createElement("a");
link.href = img ;
link.download = title;
link.click();

运行一下发现浏览器直接在标签页将图片显示出来了,并不会直接下载到本地,这是因为浏览器的预览机制:浏览器默认将图片链接视为可预览资源。

  • 若链接指向图片且未设置 download 属性,浏览器会尝试在新标签页中预览(如 .jpg/.png 等常见格式)。
  • 即使设置 download ,部分浏览器(如 Chrome)对同源图片仍可能优先预览,尤其是小尺寸图片。

转为Blob对象再下载

将图片转换为 Blob 对象后下载,可绕过浏览器预览机制

javascript 复制代码
const response = await fetch(img);
if (!response.ok) throw new Error( response.status);
const blob = await response.blob();
const blobUrl = URL.createObjectURL(blob);
const link = document.createElement("a");
link.href = blobUrl;
link.download = title + img.substring(img.lastIndexOf("."));
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
URL.revokeObjectURL(blobUrl);

这样就能成功下载了~

制作成书签工具

  • 将我们前面的代码改成一个立即执行函数,并且用 javascript: 声明
javascript 复制代码
javascript: (async () => {
  const img = document.querySelector("#wxwork-share-pic").src.split("@")[0];
  const title = document.querySelector(
    "#viewbox_report > div.video-info-title > div > h1"
  ).innerText;
  try {
    const response = await fetch(img);
    if (!response.ok) throw new Error(`HTTP error! status: ${response.status}`);
    const blob = await response.blob();
    const blobUrl = URL.createObjectURL(blob);
    const link = document.createElement("a");
    link.href = blobUrl;
    link.download = title + img.substring(img.lastIndexOf("."));
    document.body.appendChild(link);
    link.click();
    document.body.removeChild(link);
    URL.revokeObjectURL(blobUrl);
  } catch (error) {
    console.error("下载图片失败:", error);
    alert("下载失败,请检查图片URL是否有效");
  }
})();
  • 新建书签,名称改成自己喜欢的名称,再将前面写好的代码复制到网址栏就可以,后面想要下载视频封面直接点击书签就可以了~

源码

gitee

gitee.com/zheng_yongt...

github

github.com/yongtaozhen...


  • 🌟 觉得有帮助的可以点个 star~
  • 🖊 有什么问题或错误可以指出,欢迎 pr~
  • 📬 有什么想要实现的功能或想法可以联系我~

公众号

关注公众号『 前端也能这么有趣 』,获取更多有趣内容。

发送 加群 还可以加入群聊,一起来学习(摸鱼)吧~

说在后面

🎉 这里是 JYeontu,现在是一名前端工程师,有空会刷刷算法题,平时喜欢打羽毛球 🏸 ,平时也喜欢写些东西,既为自己记录 📋,也希望可以对大家有那么一丢丢的帮助,写的不好望多多谅解 🙇,写错的地方望指出,定会认真改进 😊,偶尔也会在自己的公众号『前端也能这么有趣』发一些比较有趣的文章,有兴趣的也可以关注下。在此谢谢大家的支持,我们下文再见 🙌。

相关推荐
张晓~1833994812131 分钟前
数字人源码部署流程分享--- PC+小程序融合方案
javascript·小程序·矩阵·aigc·文心一言·html5
爱喝水的小周34 分钟前
AJAX vs axios vs fetch
前端·javascript·ajax
Jinxiansen021136 分钟前
unplugin-vue-components 最佳实践手册
前端·javascript·vue.js
几道之旅40 分钟前
介绍electron
前端·javascript·electron
周胡杰42 分钟前
鸿蒙arkts使用关系型数据库,使用DB Browser for SQLite连接和查看数据库数据?使用TaskPool进行频繁数据库操作
前端·数据库·华为·harmonyos·鸿蒙·鸿蒙系统
315356691343 分钟前
ClipReader:一个剪贴板英语单词阅读器
前端·后端
玲小珑1 小时前
Next.js 教程系列(十一)数据缓存策略与 Next.js 运行时
前端·next.js
qiyue771 小时前
AI编程专栏(三)- 实战无手写代码,Monorepo结构框架开发
前端·ai编程
轻语呢喃1 小时前
React智能前端:从零开始的识图学单词项目(一)
javascript·react.js·aigc
断竿散人1 小时前
JavaScript 异常捕获完全指南(下):前端框架与生产监控实战
前端·javascript·前端框架