目次
javascript - ZeroClipboard为什么点击两次才能成功呢?上全部代码
Jun 06, 2016 pm 08:45 PM
javascript
jquery
php
プログラマー
<code> <meta charset="UTF-8"> <title>插件</title> <script src="ZeroClipboard.min.js"></script> <script> function setCopyClip(id) { clip = new ZeroClipboard.Client(); //初始化对象 ZeroClipboard.setMoviePath("ZeroClipboard.swf"); clip.setHandCursor( true ); //设置手型 var oA = document.getElementById(id); var code = oA.getAttribute('data-code'); clip.setText(code); clip.addEventListener('complete', function (client) { //创建监听事件 alert('复制成功!'); }); clip.glue(id); //将flash覆盖至指定ID的DOM上 } window.onload=function() { var aA = document.getElementsByTagName('a'); for (var i = 0; i < aA.length; i++) { aA[i].onclick=function() { setCopyClip(this.id) } } } </script> <p class="intro">券号:BBBzc1234567A473D00051 <br> <a href="javascript:;" class="hdl-copymemcode" id="BBBzc1234567A473D00051" data-code="BBBzc1234567A473D00051">复制券号</a> <br>使用状况:还未开始或已过期 </p> <p class="intro">券号:AAAzc1234567A473D00051 <br> <a href="javascript:;" class="hdl-copymemcode" id="AAAzc1234567A473D00051" data-code="AAAzc1234567A473D00051">复制券号</a> <br> 使用状况:还未开始或已过期 </p> </code>
ログイン後にコピー
ログイン後にコピー
回复内容:
<code> <meta charset="UTF-8"> <title>插件</title> <script src="ZeroClipboard.min.js"></script> <script> function setCopyClip(id) { clip = new ZeroClipboard.Client(); //初始化对象 ZeroClipboard.setMoviePath("ZeroClipboard.swf"); clip.setHandCursor( true ); //设置手型 var oA = document.getElementById(id); var code = oA.getAttribute('data-code'); clip.setText(code); clip.addEventListener('complete', function (client) { //创建监听事件 alert('复制成功!'); }); clip.glue(id); //将flash覆盖至指定ID的DOM上 } window.onload=function() { var aA = document.getElementsByTagName('a'); for (var i = 0; i < aA.length; i++) { aA[i].onclick=function() { setCopyClip(this.id) } } } </script> <p class="intro">券号:BBBzc1234567A473D00051 <br> <a href="javascript:;" class="hdl-copymemcode" id="BBBzc1234567A473D00051" data-code="BBBzc1234567A473D00051">复制券号</a> <br>使用状况:还未开始或已过期 </p> <p class="intro">券号:AAAzc1234567A473D00051 <br> <a href="javascript:;" class="hdl-copymemcode" id="AAAzc1234567A473D00051" data-code="AAAzc1234567A473D00051">复制券号</a> <br> 使用状况:还未开始或已过期 </p> </code>
ログイン後にコピー
ログイン後にコピー
给你说下程序执行的流程吧:
- 页面初始化时,
<a></a>
元素有onclick事件; - 第一次点击, 触发
onclick
事件, 调用setCopyClip
函数后, 绑定一个ZeroClipboard.Client
对象; - 这条是重点 : 在
new ZeroClipboard.Client
时,ZeroClipboard
会创建一个div
元素覆盖在<a></a>
元素之上; - 第二次点击, 因为ZeroClipboard创建的
div
在<a></a>
元素之上, 所以不会触发onclick
事件; - 第一次绑定的
ZeroClipboard.Client
对象触发complete
事件, 弹出复制成功!
弹窗.
PS:你用的ZeroClipboard版本很老的吧...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

人気の記事
スプリットフィクションを打ち負かすのにどれくらい時間がかかりますか?
3週間前
By DDD
レポ:チームメイトを復活させる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
ハローキティアイランドアドベンチャー:巨大な種を手に入れる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.説明されたエネルギー結晶と彼らが何をするか(黄色のクリスタル)
1週間前
By 尊渡假赌尊渡假赌尊渡假赌

人気の記事
スプリットフィクションを打ち負かすのにどれくらい時間がかかりますか?
3週間前
By DDD
レポ:チームメイトを復活させる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
ハローキティアイランドアドベンチャー:巨大な種を手に入れる方法
3週間前
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.説明されたエネルギー結晶と彼らが何をするか(黄色のクリスタル)
1週間前
By 尊渡假赌尊渡假赌尊渡假赌

ホットな記事タグ

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック
Gmailメールのログイン入り口はどこですか?
7134
9


Java チュートリアル
1534
14


Laravel チュートリアル
1257
25


PHP チュートリアル
1205
29


CakePHP チュートリアル
1154
46



Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド

PHP 開発用に Visual Studio Code (VS Code) をセットアップする方法
