ZeroClipboard autocopy?

时间:2015-02-21 00:37:29

标签: jquery flash zeroclipboard

ZeroClipboard是将文本复制到剪贴板的最简单,最好的方法,它使用不可见的Adobe Flash电影和JavaScript界面​​。

我尝试了它,它在这里工作,代码在这里,如果你想测试它,请点击here

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8/jquery.min.js"></script>
<script src="http://www.paulund.co.uk/playground/demo/zeroclipboard-demo/zeroclipboard/ZeroClipboard.js"></script>
<script>
   $(document).ready(function()
   {

                   var clientTarget = new ZeroClipboard( $("#target-to-copy"), {
                 moviePath: "http://www.paulund.co.uk/playground/demo/zeroclipboard-demo/zeroclipboard/ZeroClipboard.swf",
                 debug: false
               } );

               clientTarget.on( "load", function(clientTarget)
               {
                   $('#flash-loaded').fadeIn();

                   clientTarget.on( "complete", function(clientTarget, args) {
                       clientTarget.setText( args.text );
                       $('#target-to-copy-text').fadeIn();
                   } );
               } );

       });
</script>
</head>
<body>
   <p id="flash-loaded" style="display:none">Flash player is loaded.</p>
   <h2>Set Copy Target</h2>
   <p>
      <button id="target-to-copy" data-clipboard-target="clipboard-text">Click To Copy</button><br/>
      <script type="text/javascript">
         // What I've done to auto-click

         $(document).ready(function(){
             $("#target-to-copy").click(); 
         });
      </script>
      <script>
         // What I've done to auto-click

         jQuery(function(){
            jQuery('#target-to-copy').click();
         });
      </script>
      <textarea name="clipboard-text"  id="clipboard-text" >COPY ME PLEASE!!!!!
        </textarea>
   </p>
   <p id="target-to-copy-text" style="display:none;">Text Copied.</p>
   <h2>Paste Test</h2>
   <textarea name="paste-test" id="paste-test"  placeholder="Paste Text Here"></textarea>

我的问题是我想在没有任何用户点击的情况下自动复制到剪贴板。我不打算做一些邪恶的事情(我建立一个聊天机器人,我希望他根据用户的要求将文本复制到剪贴板。这是我尝试过的,点击带有id的按钮使用jquery在加载时进行目标复制;但它没有工作。

<script type="text/javascript">
             // What I've done to auto-click
             $(document).ready(function(){
                 $("#target-to-copy").click(); 
             });
</script>
<script>
             // What I've done to auto-click

             jQuery(function(){
                jQuery('#target-to-copy').click();
             });
</script>

我最好的猜测,adobe flash要求用户实际点击按钮。在加载时我(自动复制)的解决方案是什么?正如我之前所说的,我正在创建一个智能聊天机器人,用户将与机器人聊天并请求将任何内容复制到剪贴板,然后机器人将使用jquery命令进行响应以复制到剪贴板,我不会# 39;不希望任何用户点击任何内容。

1 个答案:

答案 0 :(得分:0)

根据the ZeroClipboard documentation,,这是不可能的:

  

限制

     

需要用户交互

     

由于浏览器和Flash安全限制,当用户点击不可见的Flash影片时,此剪贴板注入可以 。来自JavaScript的模拟click事件不足以支持clipboard poisoning

There are other ways to programmatically set the clipboard text但它们也需要某种用户交互 - 例如,Ctrl-C(或Command-C)。