用浏览器实现一个屏幕录制功能

用浏览器实现一个屏幕录制功能

省流

将这段代码复制到控制台点击 '屏幕录制' 按钮

js 复制代码
const button = document.createElement("button");
button.innerHTML = "屏幕录制";
button.style = "position: fixed; top:200px; z-index: 99999999999;";
document.body.append(button);
button.addEventListener("click", async () => {
  const stream = await navigator.mediaDevices.getDisplayMedia();

  const recoder = new MediaRecorder(stream);
  recoder.start();
  const [video] = stream.getVideoTracks();
  const [video] = stream.getVideoTracks();
  video.addEventListener("ended", () => {
    recoder.stop();
  });
  recoder.addEventListener("dataavailable", (evt) => {
    const a = document.createElement("a");
    a.href = URL.createObjectURL(evt.data);
    a.download = "capture.webm";
    a.click();
  });
});

解析

  1. document.createElement("button") 创建一个 button ,填充文字,添加到 body 上
  2. 为了安全考虑,只监听用户行为来触发
  3. navigator.mediaDevices.getDisplayMedia() 来提示用户去选择和授权捕获展示的内容或部分内容
  4. MediaRecorder 来进行媒体录制的接口
  5. 创建 a 标签来保存录制数据,并且下载

使用场景

  • 提供给测试,能够快速屏幕录制
  • 代码演示
  • 其它用法去评论区留言,让大家开开眼

配合使用

在线文件转换:convertio.co/zh/download...

图片压缩:docsmall.com/

兼容性

  • getDisplayMedia

  • MediaRecorder()

参考

developer.mozilla.org/zh-CN/docs/...

developer.mozilla.org/zh-CN/docs/...

dev.to/ninofiliu/s...

相关推荐
147API7 小时前
Claude Opus 4.8 接口与工程落地分析:长任务调用链应该怎么设计
java·前端·数据库
李子琪。7 小时前
Web 漏洞与防御机制实验报告
前端·经验分享
JustNow_Man8 小时前
“失败后自动拉起修复 Agent”的闭环流水线
前端·人工智能·chrome·python
Dxy12393102168 小时前
HTML中如何写键盘事件
前端·html·计算机外设
霍格沃兹测试学院-小舟畅学8 小时前
接口自动化测试的下一个十年:从脚本到Skills,让AI学会“如何测”
java·前端·人工智能
huangfuyk8 小时前
前端使用Cursor编辑器方面遇到的问题及注意细节
前端·编辑器·ai编程·cursor
ZC跨境爬虫8 小时前
跟着 MDN 学CSS day_31:(精通链接样式,从伪类到导航菜单)
前端·javascript·css·ui·交互
发现你走远了8 小时前
前端多环境自动化部署实战:GitHub Actions + Azure Blob + Cloudflare
前端·自动化·github
香香爱编程8 小时前
vue3自定义顶部弹窗
前端·javascript·vue.js
weelinking8 小时前
【产品】10_搭建前端框架——把你的原型变成真实页面
java·大数据·前端·数据库·人工智能·python·前端框架