clipboard-polyfill

简单的网页复制,最大限度的兼容浏览器。「Simple copying on the web, with maximum browser compatibility.」

Github星跟蹤圖

Logo for clipboard-polyfill: an icon of a clipboard fading into a drafting paper grid.

clipboard-polyfill

Make copying on the web as easy as:

clipboard.writeText("hello world");

As of October 2017, this library is a polyfill for the modern Promise-based asynchronous clipboard API.
(Note: the core library doesn't modify global objects, so it's actually a ponyfill.)

Why clipboard-polyfill?

Browsers have implemented several clipboard APIs over time, and writing to the clipboard without triggering bugs in various old and current browsers is fairly tricky. In every browser that supports copying to the clipboard in some way, clipboard-polyfill attempts to act as close as possible to the async clipboard API. (Read to the end of this document for all the limitations.)

See this presentation for for a longer history of clipboard access on the web.

Note: If you only need to copy text and want a super simple polyfill that gets you 80% of the way, consider using this gist.

Get the Code

Get the code using one of the following. If you don't know how to pick and want maximum browser compatibility, start by using "With Promise Polyfill".

Without Promise Polyfill

This version is smaller, but does not work in Internet Explorer unless you add your own Promise polyfill (see below).

  • Download clipboard-polyfill.js and include it using a <script> tag.
  • npm install clipboard-polyfill and one of:
    • import * as clipboard from "clipboard-polyfill"
    • const clipboard = require("clipboard-polyfill");

With Promise Polyfill

This version works "out of the box" in all browsers that support copying to the clipboard, but is larger.

  • Download clipboard-polyfill.promise.js and include it using a <script> tag.
  • npm install clipboard-polyfill and one of:
    • import * as clipboard from "clipboard-polyfill/dist/clipboard-polyfill.promise"
    • const clipboard = require("clipboard-polyfill/dist/clipboard-polyfill.promise");

Note: the Promise polyfill in this build version will modify the global object.

Which One?

The async clipboard API design uses ES6 Promise, which is not supported in Internet Explorer. If you want the clipboard-polyfill to work in as many browsers as possible, you will need to include a polyfill for Promise. You can do this by either using the "With Promise Polyfill" version, or by using the "Without Promise Polyfill" version with a polyfill of your own choice. Recommendations include es6-promise and core-js. Instructions for how to use these polyfills are dependent on your build system and can be found in the READMEs of these libraries.

Usage

Plain Text

Copy text to the clipboard (all modern browsers):

clipboard.writeText("This text is plain.");

Read text from the clipboard (IE 9-11 and Chrome 65+):

clipboard.readText().then(console.log, console.error);

Caveats:

  • Browsers may require a user gesture or user permission to access the clipboard. In particular, you should write text only in response to an event listener, e.g. a button click listener.
  • Reading fails if the clipboard does not contain text/plain data.

Other Data Types (e.g. HTML)

Write (all modern browsers):

var dt = new clipboard.DT();
dt.setData("text/plain", "Fallback markup text.");
dt.setData("text/html", "<i>Markup</i> <b>text</b>.");
clipboard.write(dt);

Read (IE 9-11, Chrome 65+):

// The success callback receives a clipboard.DT object.
clipboard.read().then(console.log, console.error);

Caveats:

  • Currently, text/plain and text/html are the only data types that can be written to the clipboard across most browsers.
  • Unsupported data types will be silently dropped. In general, it is not possible to tell which data types will be dropped.
  • This part of the clipboard API is still under active discussion, and may change.
  • Currently, reading will only return the text/plain data type, if it is on the clipboard.

Interface

clipboard {
  static write:     (data: clipboard.DT)  => Promise<void>
  static writeText: (s: string) => Promise<void>
  static read:      () => Promise<clipboard.DT>
  static readText:  () => Promise<string>
  static suppressWarnings: () => void
}

clipboard.DT {
  constructor()
  setData: (type: string, value: string): void
  getData: (type: string): string

主要指標

概覽
名稱與所有者lgarron/clipboard-polyfill
主編程語言TypeScript
編程語言HTML (語言數: 5)
平台Web browsers
許可證
所有者活动
創建於2015-03-27 02:10:34
推送於2025-05-28 06:24:39
最后一次提交
發布數69
最新版本名稱v4.1.1 (發布於 )
第一版名稱v0.1.0 (發布於 )
用户参与
星數0.9k
關注者數8
派生數100
提交數557
已啟用問題?
問題數136
打開的問題數9
拉請求數25
打開的拉請求數0
關閉的拉請求數8
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?