Clipboard.js:不用 Flash 实现剪贴板功能的轻量级 JavaScript 库

  • David Iffland
  • 刘振涛

2015 年 10 月 8 日

话题:JavaScriptHTML5语言 & 开发

Zeno Rocha 发布了一个专门用于从 web 页面向本地计算机的剪贴板复制文本的 JavaScript 库:Clipboard.js

在每一个 Github 仓库页面的侧边栏上都有一个小部件,用来显示 repo 的 HTTPS 克隆地址,当你点击紧挨着这个部件的按钮时,就会复制当前 repo 的 URL 到用户的剪贴板中。Github 用 JavaScript 库ZeroClipboard来实现这一功能,问题是这个库是用一个不可见的 Flash 来完成剪贴操作,而 Flash 技术正被各大浏览器厂商冷落,所以势必要有一个新的方案。

在今年的早些时候,Firefox 浏览器默认禁用了 Flash,需要用户明确启用 Flash 才可以通过它向剪贴板中复制文本。

Mozilla Hacks上的一篇文章中示范了 API document.execCommand()的使用方法。MDN 的文档中称,execCommand“赋予了浏览器通过运行指令操作可编辑区域内容的能力。”直到 Firefox 41 发布,“cut”和“copy”指令才正式启用。

浏览器只允许用户主动触发这样的事件,不允许 JavaScript 代码随意将文本复制到剪贴板中,如果代码尝试越过用户自行复制,该调用会失败。

Rocha 借鉴了一些思路:通过给 execCommand 传递参数指令来执行相关操作;集成Selection API。通过结合这些技术,Clipboard.js 为开发者提供了一个集成了实用的 API 的多功能轻量级 JavaScript 库。如果想要将按钮与库绑定,开发者需要声明触发剪贴板的元素:


var clipboard = new Clipboard('.btn');

主流浏览器都支持这个库,Safari 目前仍不支持 cut 和 copy 指令。

ZeroClipboard 的开发者在讨论中声称也要在他们的库中加入相同的 API 的支持,当这些 API 不被支持时提供向后兼容的 Flash 功能。ZeroClipboard 的贡献者 James Green 谈起 Clipboard.js 时说到:“它是一个很好的轻量级选择,但是我知道,很多用户的使用环境不是最新的主流浏览器,ZeroClipboard 在向后兼容 Flash 的同时支持新的 HTML5 特性对这些用户来说至关重要。”

HTML5 的剪贴板 API的提案仍然处于议程中,在大多数浏览器只实现了部分支持

查看英文原文Lightweight JavaScript Library Offers Flash-Free Clipboard Integration

JavaScriptHTML5语言 & 开发