我正在尝试使用ZeroClipboard将文本复制到剪贴板。 它工作正常,但仅在第二次单击按钮而不是第一次单击时。 我在谷歌看到的解决方案很少,但没有一个能解决我的问题。 谢谢!
$("body").on('click','.copyToClipboard', function (event) {
var clientTarget = new ZeroClipboard( $("#copy_to_clipboard"), {
moviePath: "js/ZeroClipboard.swf",
debug: false
} );
$('#copy_to_clipboard').attr('data-clipboard-text', texttocopy);
alert(texttocopy);
clientTarget.on( "load", function(clientTarget)
{
$('#flash-loaded').fadeIn();
clientTarget.on( "complete", function(clientTarget, args) {
clientTarget.setText( args.text );
$('#data-to-copy-text').fadeIn();
} );
alert(args);
} );
});
答案 0 :(得分:1)
您需要在点击功能之外初始化剪贴板,例如
var clientTarget = new ZeroClipboard($("#copy_to_clipboard").attr('data-clipboard-text',texttocopy ),{
moviePath: "js/ZeroClipboard.swf",
debug: false
}).on( "load", function(clientTarget){
$('#flash-loaded').fadeIn();
clientTarget.on( "complete", function(clientTarget, args) {
clientTarget.setText( args.text );
$('#data-to-copy-text').fadeIn();
});
alert(args);
});
// get the text only on click of .copyToClipboard
$("body").on('click','.copyToClipboard', function (event) {
var texttocopy = $('#copy_to_clipboard').attr('data-clipboard-text');
alert(texttocopy);
});