ZeroClipboard 复制文本到剪切板

发布于 2017-04-25 13:14:46 字数 7088 浏览 1929 评论 0

ZeroClipboard 是一个基于原生的JavaScript复制插件,使用 ZeroClipboard 可以简单的将内容复制到剪贴板,通过 Adobe Flash 和 JavaScript 脚本来实现。插件名称中的Zero 意义为这个类库没有界面,界面需要由你来建立,提供了一些可用的方法和函数。

使用方法

载入 JavaScript 文件

<script src="ZeroClipboard.js"></script>

如果 ZeroClipboard.swf 与页面不在同一个目录下,可以设置路径

// 全局设置
ZeroClipboard.setDefaults({
  moviePath: '/path/ZeroClipboard.swf'
});

// 参数中设置
var clip=new ZeroClipboard(document.getElementById("copy-button"), {
  moviePath: '/path/ZeroClipboard.swf'
});

调用

可以传递一个元素或者一个元素数组。(这里使用 jQuery 获取元素的方式)

// 直接调用
var clip=new ZeroClipboard($('#my-button'));

AMD

如果你使用 RequireJSCurl.jsSeajsAMD 规范的模块加载器,那么需要设置模块的 ID 或者路径的值到 amdModuleId,才能正常使用 ZeroClipboard,例如:

define(['path/to/zero-clipboard'], function(ZeroClipboard){
  ZeroClipboard.setDefaults({
    amdModuleId: 'path/to/zero-clipboard'
  });
});

或者设置路径,RequireJS 的例子:

requirejs.config({
  paths:{
    "ZeroClipboard":"path/to/zero-clipboard"
  }
});

define(["ZeroClipboard"],function(ZeroClipboard) {
  ZeroClipboard.setDefaults({
    amdModuleId: 'ZeroClipboard'
  });
});

参数说明

new ZeroClipboard(elements [, options])

options 参数说明

名称默认值说明
swfPath"ZeroClipboard.swf"Flash 文件路径,默认的 swf 文件路径与 ZeroClipboard.js 相同
trustedDomainswindow.location.host ? [window.location.host] : []可信任的域(字符串或者字符串的数组)
cacheBusttrue
forceEnhancedClipboardfalse
flashLoadTimeout30000加载 Flash 的超时时间,如果不需要,可以设置为 0。单位(ms)
autoActivatetrue
bubbleEventstrue
containerId"global-zeroclipboard-html-bridge"
containerClass"global-zeroclipboard-container"
swfObjectId"global-zeroclipboard-flash-bridge"
hoverClass"zeroclipboard-is-hover"鼠标移上时给元素增加的 Class
activeClass"zeroclipboard-is-active"选定是给元素增加的 Class
forceHandCursorfalse
titlenull
zIndex999999999

参数 allowScriptAccess 选项的注意事项

1.1.7 及以下的版本,allowScriptAccess 的默认值为 always。意味着允许 "ZeroClipboard.swf" 文件托管的其他的域。为了提高安全性,1.1.7 之后的版本,allowScriptAccess 的默认值为 sameDomain,只允许 "ZeroClipboard.swf" 在相同域之下。

如果你是从 1.1.7 或更低的版本升级到 1.1.7 以上版本时,需要将 "ZeroClipboard.swf" 保存一份到相同域之下,或者设置 allowScriptAccess 的值为 always。

关于 allowScriptAccess 的更多信息,可以参考官方文档

Data 属性

名称说明
data-clipboard-target元素ID。查找该元素后,尝试复制元素的 .value.textContent.innerText 的值
data-clipboard-text默认复制的内容。

同时设置 data-clipboard-targetdata-clipboard-text 两个属性时,只有在找不到 clipboard-target 的值时才会选用 clipboard-text

即使获取到 clipboard-target 的值为空,也不会选用 clipboard-text

API 方法

名称说明
glue(dom)绑定到元素
reposition()调整位置
on("Event",my_load_handler)绑定事件
off("Event",my_load_handler)取消已绑定的事件

事件

通过 API 的方法 on() 来绑定

名称示例说明
loadclip.on("load",function(client,args){...});Flash 加载完成时的事件。args 参数包含以下属性:

flashVersion:当前 Flash 的版本号

mouseoverclip.on("mouseover",function(client,args){...});鼠标移入时的事件。args 参数包含以下属性:

flashVersion:当前 Flash 的版本号

altKey:是否按住 Alt 键

ctrlKey:是否按住 Ctrl 键

shiftKey:是否按住 Shift 键

mouseoutclip.on("mouseout",function(client,args){...});鼠标移出时的事件。args 参数包含以下属性:

flashVersion:当前 Flash 的版本号

altKey:是否按住 Alt 键

ctrlKey:是否按住 Ctrl 键

shiftKey:是否按住 Shift 键

mousedownclip.on("mousedown",function(client,args){...});鼠标按下时的事件。args 参数包含以下属性:

flashVersion:当前 Flash 的版本号

altKey:是否按住 Alt 键

ctrlKey:是否按住 Ctrl 键

shiftKey:是否按住 Shift 键

mouseupclip.on("mouseup",function(client,args){...});鼠标弹起时的事件。args 参数包含以下属性:

flashVersion:当前 Flash 的版本号

altKey:是否按住 Alt 键

ctrlKey:是否按住 Ctrl 键

shiftKey:是否按住 Shift 键

completeclip.on("complete",function(client,args){...});成功复制内容时的事件。args 参数包含以下属性:

flashVersion:当前 Flash 的版本号

altKey:是否按住 Alt 键

ctrlKey:是否按住 Ctrl 键

shiftKey:是否按住 Shift 键

text:复制的内容

noflashclip.on("noflash",function(client,args){...});没有检测到 Flash 时的事件。
wrongflashclip.on("wrongflash",function(client,args){...});Flash 版本低于要求版本时的事件。ZeroClipboard 要求 Flash 10.0.0 以上的版本。
dataRequestedclip.on("dataRequested",function(client,args){...});复制开始时的事件

相关链接

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

文章
评论
84963 人气
更多

推荐作者

微信用户

文章 0 评论 0

小情绪

文章 0 评论 0

ゞ记忆︶ㄣ

文章 0 评论 0

笨死的猪

文章 0 评论 0

彭明超

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文