我使用ZClip(http://www.steamdev.com/zclip/)在多个链接的网页上启用“复制到剪贴板”功能。在这种情况下,我面临两个问题:
我在链接上初始化zclip之前尝试使用$('a.copy').zclip('remove');
。此功能显示在zclip网站上,但它没有导致删除额外的警报框。它只删除与链接关联的swf,而不是绑定到链接的事件。基本上我想了解如何做以下任何一项指导:
答案 0 :(得分:5)
Saganbyte,
我想到了几种方法。
首先,让我们假设您的四个图像/视频/音频/文档div中的每一个的HTML都是这样的:
<div class="content" ...>
...
<input class="copyMe" /><!-- the element whose value is to be copied -->
</div>
这两种方法都依赖于单个“复制”按钮,当zClip初始化时,该按钮是可见的:
<a id="copy">Copy</a>
您的HTML无疑是不同的,但是根据以下想法进行调整应该相当简单。
此解决方案依赖于:
class="copyWrapper"
提供一个空元素(例如,span或div),其中“copy”按钮可以移动到其中.copyWrapper
元素中。按如下方式初始化zClip:
var $copyButton = $('a#copy').zclip({
path: 'js/ZeroClipboard.swf',
copy: function() {
return $(this).closest('div.content').find('.copyMe').val(); //$(this) is assumed correct
}
});
并初始化选项卡(假设jQuery UI“tabs”),如下所示:
$(".selector").tabs({
...
show: function(event, ui) {
$(ui.panel).find('.copyWrapper').append($copyButton);
}
});
此解决方案依赖于:
按如下方式初始化zClip:
$('a#copy').zclip({
path: 'js/ZeroClipboard.swf',
copy: function(){
return $('.content:visible').find('.copyMe').val();
}
});
此解决方案依赖于:
的javascript:
$(".selector").tabs({
...
show: function(event, ui) {
var $panel = $(ui.panel);
if(!$panel.data('zClip_initialized')) { //If zClip not initialized in theis panel, then initialize it.
$('a.copy').zclip({
path: 'js/ZeroClipboard.swf',
copy: function() {
return $(this).closest('tr').find('.....').val();//Lots of guesswork here. You should have written this already.
}
});
$panel.data('zClip_initialized', true);//Raise a boolean flag to indicate that zClip is already initialized
}
}
});