無需 Flash 使用 jQuery 復(fù)制文字到剪貼板
如果在網(wǎng)上找一個關(guān)于如何將一段特定的文本拷貝到剪貼板的解決方案,最可能的結(jié)果就是使用Flash的方案來做這個事,雖然使用Flash可以很好地解決這個問題,但是這不是一個明智的想法,因為這個產(chǎn)品最終會消失或者至少是瀏覽器不再提供支持,因此這個解決方案是沒有未來的。雖然可以使用jQuery或者純JavaScript,甚至完全自己寫,但是當有人已經(jīng)創(chuàng)建了一個解決方案,那么為什么還要重復(fù)發(fā)明輪子呢?讓我們一起看看Clipboard.js吧。
Clipboard.js刪除了Flash組件并且優(yōu)雅地解決了這個問題,需要做的只是引入其腳本,在HTML標簽上賦一個“data-clipboard-target”屬性然后寫一小段JavaScript片段。為了演示假定有一個貨幣轉(zhuǎn)換應(yīng)用,在一個文本框中輸入數(shù)值時同時將兌換結(jié)果顯示在另一個文本框中,當點擊文本框時,會觸發(fā)事件將其復(fù)制到剪貼板然后顯示一條消息。
下面是我的實現(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>
你有沒有注意到我有一個 AmountTo和 一個AmountFrom,AmountTo是輸入AmountFrom 是輸出 ,當我們點擊這個的時候其值就會傳給剪切板。這個神奇的事情發(fā)生在屬性“data-clipboard-target”里面。
我們也添加一個消息框用來顯示拷貝動作消息
<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>
至此,會發(fā)現(xiàn)我們只是引入了clipoard.js,如果實例化Clipboard成功,然后會給事件賦予一些動作,否則它會觸發(fā)一個錯誤,是這樣吧?這一切都很好,它能兼容所有最新的瀏覽器,除了IE,它會給出下面這樣的一個消息。
如果希望看一下實際的效果,這是一個JSFiddle示例。
接下來就是抓取剪貼板的數(shù)據(jù)然后當點擊時自動地粘貼到一個文本框,至此,看上去瀏覽器因為一個安全上的風險會阻止它,但是我會嘗試找到甚至做出一個方案,因此大家還得繼續(xù)關(guān)注。
相關(guān)文章
jQuery對象和DOM對象之間相互轉(zhuǎn)換的方法介紹
這篇文章主要介紹了jQuery對象和DOM對象之間相互轉(zhuǎn)換的方法介紹,本文講解了jQuery對象轉(zhuǎn)成DOM對象、DOM對象轉(zhuǎn)換成jQuery對象 方法,需要的朋友可以參考下2015-02-02jQuery zTree 異步加載添加子節(jié)點重復(fù)問題
zTree 是一個依靠 jQuery 實現(xiàn)的多功能 “樹插件”。下面通過本文給大家分享jQuery zTree 異步加載添加子節(jié)點重復(fù)問題,需要的朋友參考下吧2017-11-11ASP.NET jQuery 實例18 通過使用jQuery validation插件校驗DropDownList
這節(jié)我們還可以通過直接設(shè)置DropDownList屬性來設(shè)置jQuery validation插件的校驗規(guī)則和提示信息2012-02-02javascript向后臺傳送相同屬性的參數(shù)即數(shù)組參數(shù)
在傳送參數(shù)時,經(jīng)常會碰到向后臺傳送一些相同屬性的參數(shù),最好的選擇是采用數(shù)組的方式,下面有個不錯的示例,大家可以參考下2014-02-02