無需 Flash 使用 jQuery 復(fù)制文字到剪貼板
如果在網(wǎng)上找一個(gè)關(guān)于如何將一段特定的文本拷貝到剪貼板的解決方案,最可能的結(jié)果就是使用Flash的方案來做這個(gè)事,雖然使用Flash可以很好地解決這個(gè)問題,但是這不是一個(gè)明智的想法,因?yàn)檫@個(gè)產(chǎn)品最終會(huì)消失或者至少是瀏覽器不再提供支持,因此這個(gè)解決方案是沒有未來的。雖然可以使用jQuery或者純JavaScript,甚至完全自己寫,但是當(dāng)有人已經(jīng)創(chuàng)建了一個(gè)解決方案,那么為什么還要重復(fù)發(fā)明輪子呢?讓我們一起看看Clipboard.js吧。
Clipboard.js刪除了Flash組件并且優(yōu)雅地解決了這個(gè)問題,需要做的只是引入其腳本,在HTML標(biāo)簽上賦一個(gè)“data-clipboard-target”屬性然后寫一小段JavaScript片段。為了演示假定有一個(gè)貨幣轉(zhuǎn)換應(yīng)用,在一個(gè)文本框中輸入數(shù)值時(shí)同時(shí)將兌換結(jié)果顯示在另一個(gè)文本框中,當(dāng)點(diǎn)擊文本框時(shí),會(huì)觸發(fā)事件將其復(fù)制到剪貼板然后顯示一條消息。 
下面是我的實(shí)現(xiàn)。
假如這是你的文本框。(我使用MVC框架創(chuàng)建我的應(yīng)用程序)
<divclass="row"><divclass="col-md-6">From<divclass="input-group">
<divclass="input-group-addon">$</div>
@Html.EditorFor(model=>model.AmountFrom,new{htmlAttributes=new{@class="form-controlinput-largest",@step="0.01",@type="number"}})
</div></div><divclass="col-md-6">To<divclass="input-group"><divclass="input-group-addon">$
</div><inputtype="text"id="AmountTo"value="@Model.AmountTo"class="form-controlinput-largest"readonlydata-clipboard-action="copy"data-clipboard-target="#AmountTo"/>
</div>
</div>
</div>
你有沒有注意到我有一個(gè) AmountTo和 一個(gè)AmountFrom,AmountTo是輸入AmountFrom 是輸出 ,當(dāng)我們點(diǎn)擊這個(gè)的時(shí)候其值就會(huì)傳給剪切板。這個(gè)神奇的事情發(fā)生在屬性“data-clipboard-target”里面。
我們也添加一個(gè)消息框用來顯示拷貝動(dòng)作消息
<divclass="row"> <divclass="col-md-6"><br/> <spanid="messageBox"class="text-success"style="display:block;text-align:center"></span></div></div>
到這里就是你所關(guān)心的HTML部分?,F(xiàn)在讓我們?nèi)タ碕avaScript/jQuery 部分
<scriptsrc="~/Scripts/clipboard.min.js">
</script>
<script>varclipboard=newClipboard('#AmountTo');
clipboard.on('success',function(e){$("#messageBox").text("AmountSuccessfullyCopied!").show().fadeOut(2000);e.clearSelection();});clipboard.on('error',function(e){$("#messageBox").text("ErrorCopyingAmount").show().fadeOut(2000);});$('#AmountFrom').click(function(){$("#AmountFrom").val("");});
</script>
至此,會(huì)發(fā)現(xiàn)我們只是引入了clipoard.js,如果實(shí)例化Clipboard成功,然后會(huì)給事件賦予一些動(dòng)作,否則它會(huì)觸發(fā)一個(gè)錯(cuò)誤,是這樣吧?這一切都很好,它能兼容所有最新的瀏覽器,除了IE,它會(huì)給出下面這樣的一個(gè)消息。

如果希望看一下實(shí)際的效果,這是一個(gè)JSFiddle示例。
接下來就是抓取剪貼板的數(shù)據(jù)然后當(dāng)點(diǎn)擊時(shí)自動(dòng)地粘貼到一個(gè)文本框,至此,看上去瀏覽器因?yàn)橐粋€(gè)安全上的風(fēng)險(xiǎn)會(huì)阻止它,但是我會(huì)嘗試找到甚至做出一個(gè)方案,因此大家還得繼續(xù)關(guān)注。
相關(guān)文章
jQuery使用empty()方法刪除元素及其所有子元素的方法
這篇文章主要介紹了jQuery使用empty()方法刪除元素及其所有子元素的方法,涉及jQuery操作元素的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
js頁面滾動(dòng)時(shí)層智能浮動(dòng)定位實(shí)現(xiàn)(jQuery/MooTools)
關(guān)于層的智能浮動(dòng)效果早在幾年前我就在國外的一些個(gè)人網(wǎng)站的垂直導(dǎo)航上見到了,現(xiàn)在似乎在國內(nèi)一些商業(yè)網(wǎng)站上也屢見此效果2011-08-08
jQuery實(shí)現(xiàn)淡入淡出的模態(tài)框
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)淡入淡出的模態(tài)框,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
jQuery實(shí)現(xiàn)dialog設(shè)置focus焦點(diǎn)的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)dialog設(shè)置focus焦點(diǎn)的方法,涉及jQuery針對dialog的操作技巧,需要的朋友可以參考下2015-06-06
jQuery使用siblings獲取某元素所有同輩(兄弟姐妹)元素用法示例
這篇文章主要介紹了jQuery使用siblings獲取某元素所有同輩(兄弟姐妹)元素用法,結(jié)合簡單實(shí)例形式分析了siblings()函數(shù)獲取同輩元素的操作技巧,需要的朋友可以參考下2017-01-01
jQuery實(shí)現(xiàn)HTML元素隱藏和顯示
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)HTML元素隱藏和顯示,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
PHP+jQuery實(shí)現(xiàn)隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置
本文講解了如何采用PHP+MySQL+jQuery,實(shí)現(xiàn)隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置。 十分的實(shí)用,有需要的小伙伴可以參考下。2015-04-04

