Jquery - ZeroClipboard仅在第二次点击时起作用

时间:2015-03-16 08:45:47

标签: javascript jquery zeroclipboard

我正在尝试使用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);
    } );

});

1 个答案:

答案 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);
});