js復(fù)制文本到粘貼板(Clipboard.writeText())
復(fù)制文本到粘貼板(Clipboard.writeText())
js如何復(fù)制文本到粘貼板呢,網(wǎng)上所說(shuō)的各種復(fù)制。。在Chrome或者說(shuō)在我這個(gè)項(xiàng)目都沒(méi)用。
- windows.copy
- document.execCommand(“copy”);
- clipboard.js
- Clipboard.writeText() ,可行!
網(wǎng)上的代碼
通過(guò) document.execCommand('copy') 來(lái)操作。
//創(chuàng)建選中范圍 var range = document.createRange(); range.selectNode(copyDom); //移除剪切板中內(nèi)容 window.getSelection().removeAllRanges(); //添加新的內(nèi)容到剪切板 window.getSelection().addRange(range); //復(fù)制 var successful = document.execCommand('copy');
通過(guò) window.clipboardData.setData('Text',textVal) 這個(gè) 對(duì)象來(lái)操作的。可是都不work。
/** * 復(fù)制代碼 */ $('#btnCopy').bind('click', function (e) { if (!$.isEmptyObject(codeData)) { //support IE var clipboardData = window.clipboardData; //support Chrome/Firefox if (!clipboardData) { clipboardData = e.originalEvent.clipboardData; } if (!clipboardData) { console.log(clipboardData); console.log(clipboardData.getData('text')); clipboardData.setData('Text', codeData[id]); } if(window != undefined){ window.copy($("#genCodeArea").val()); } } });
clipboard.js
拷貝文字不應(yīng)當(dāng)是一件困難的事. 不需要過(guò)多繁雜的配置或者下載很多腳本文件. 最重要的,它不應(yīng)該依賴(lài)flash或者其他框架,應(yīng)該保持簡(jiǎn)潔,clipboard.js
1.通過(guò)cdn引入
<script src="http://cdn.staticfile.org/clipboard.js/2.0.4/clipboard.min.js"></script>
2.使用功能
<!-- Target --> <input id="copyArea" value="https://zhengkai.blog.csdn.net"> <!-- Trigger --> <button class="btn" data-clipboard-target="#copyArea"> <img src="assets/clippy.svg" alt="Copy to clipboard"> </button>
3.查看效果
4.這個(gè)功能正常是可以的,但是可能我用了CodeMirror或者其他js導(dǎo)致沖突。
Clipboard.writeText()
以下場(chǎng)景是來(lái)自CodeGenerator的復(fù)制功能:
$('#btnCopy').on('click', function(){ if(!$.isEmptyObject(genCodeArea.getValue())&&!$.isEmptyObject(navigator)&&!$.isEmptyObject(navigator.clipboard)){ navigator.clipboard.writeText(genCodeArea.getValue()); layer.msg("復(fù)制成功"); } });
來(lái)源:https://developer.mozilla.org/en-US/docs/Web/API/Clipboard/writeText
兼容性:Chrome66以上/Firefox63以上
效果展示:
復(fù)制內(nèi)容到剪貼板(無(wú)插件,兼容所有瀏覽器)
HTML部分:
<button onclick="copyToClip('內(nèi)容')"> Copy </button>
JS部分:
/** ?* 復(fù)制單行內(nèi)容到粘貼板 ?* content : 需要復(fù)制的內(nèi)容 ?* message : 復(fù)制完后的提示,不傳則默認(rèn)提示"復(fù)制成功" ?*/ function copyToClip(content, message) { ? ? var aux = document.createElement("input");? ? ? aux.setAttribute("value", content);? ? ? document.body.appendChild(aux);? ? ? aux.select(); ? ? document.execCommand("copy");? ? ? document.body.removeChild(aux); ? ? if (message == null) { ? ? ? ? alert("復(fù)制成功"); ? ? } else{ ? ? ? ? alert(message); ? ? } }
【補(bǔ)充】
如果你想復(fù)制多行數(shù)據(jù)的話,可以采用如下方法。
/** ?* 復(fù)制多行內(nèi)容到粘貼板 ?* contentArray: 需要復(fù)制的內(nèi)容(傳一個(gè)字符串?dāng)?shù)組) ?* message : 復(fù)制完后的提示,不傳則默認(rèn)提示"復(fù)制成功" ?*/ function copyToClip(contentArray, message) { ?? ?var contents = ""; ?? ?for (var i = 0; i < contentArray.length; i++) { ?? ??? ?contents += contentArray[i] + "\n"; ?? ?} ?? ?const textarea = document.createElement('textarea'); ?? ?textarea.value = contents; ?? ?document.body.appendChild(textarea); ?? ?textarea.select(); ?? ?if (document.execCommand('copy')) { ?? ??? ?document.execCommand('copy'); ?? ?} ?? ?document.body.removeChild(textarea); ? ? if (message == null) { ? ? ? ? alert("復(fù)制成功"); ? ? } else{ ? ? ? ? alert(message); ? ? } }
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- JavaScript實(shí)現(xiàn)一鍵復(fù)制文本功能的示例代碼
- Web js實(shí)現(xiàn)復(fù)制文本到粘貼板
- 使用js實(shí)現(xiàn)復(fù)制功能
- 使用?JS?復(fù)制頁(yè)面內(nèi)容的三種方案
- JavaScript實(shí)現(xiàn)一鍵復(fù)制內(nèi)容剪貼板
- JS實(shí)現(xiàn)一鍵復(fù)制
- Vue中使用highlight.js實(shí)現(xiàn)代碼高亮顯示以及點(diǎn)擊復(fù)制
- js實(shí)現(xiàn)復(fù)制粘貼的兩種方法
- JavaScript+Html5實(shí)現(xiàn)按鈕復(fù)制文字到剪切板功能(手機(jī)網(wǎng)頁(yè)兼容)
- JS實(shí)現(xiàn)復(fù)制內(nèi)容到剪貼板功能兼容所有瀏覽器(推薦)
- js實(shí)現(xiàn)點(diǎn)擊復(fù)制當(dāng)前文本到剪貼板功能(兼容所有瀏覽器)
- 簡(jiǎn)單實(shí)現(xiàn)兼容各大瀏覽器的js復(fù)制內(nèi)容到剪切板
- JavaScript 實(shí)現(xiàn)完美兼容多瀏覽器的復(fù)制功能代碼
- 兼容主流瀏覽器的JS復(fù)制內(nèi)容到剪貼板
- js實(shí)現(xiàn)的復(fù)制兼容chrome和IE
- 兼容所有瀏覽器的js復(fù)制插件Zero使用介紹
- 用js將內(nèi)容復(fù)制到剪貼板兼容瀏覽器
- js復(fù)制網(wǎng)頁(yè)內(nèi)容并兼容各主流瀏覽器的代碼
- JS復(fù)制內(nèi)容到剪切板的實(shí)例代碼(兼容IE與火狐)
- JS/FLASH實(shí)現(xiàn)復(fù)制代碼到剪貼板(兼容所有瀏覽器)
- 多瀏覽器兼容性比較好的復(fù)制到剪貼板的js代碼
- GWT中復(fù)制到剪貼板 js+flash實(shí)現(xiàn)復(fù)制 兼容性比較好
- 兼容IE與Firefox的js 復(fù)制代碼
- JavaScript 復(fù)制功能代碼 兼容多瀏覽器
- 至2023年最好用的兼容多瀏覽器的原生js復(fù)制函數(shù)copyText
相關(guān)文章
JS實(shí)現(xiàn)密碼框的顯示密碼和隱藏密碼功能示例
這篇文章主要介紹了JS實(shí)現(xiàn)密碼框的顯示密碼和隱藏密碼功能,涉及javascript針對(duì)頁(yè)面form表單元素動(dòng)態(tài)操作的相關(guān)技巧,需要的朋友可以參考下2016-12-12iframe父頁(yè)面獲取子頁(yè)面參數(shù)的方法
這篇文章主要介紹了iframe父頁(yè)面獲取子頁(yè)面參數(shù)的方法,需要的朋友可以參考下2014-02-02JavaScript獲取圖片真實(shí)大小代碼實(shí)例
這篇文章主要介紹了JavaScript獲取圖片真實(shí)大小代碼實(shí)例,本文使用onload事件來(lái)獲取圖片的真實(shí)大小,需要的朋友可以參考下2014-09-09部分網(wǎng)站允許空白referer的防盜鏈圖片的js破解代碼
主要是有些網(wǎng)站的圖片調(diào)用是防盜鏈的但一般只是判斷referer是不是自己網(wǎng)站,如果referer為空也會(huì)顯示圖片,所以有了下面的代碼。2011-05-05微信小程序web-view環(huán)境下H5跳轉(zhuǎn)小程序頁(yè)面方法實(shí)例代碼
微信小程序是一種全新的連接用戶與服務(wù)的方式,它可以在微信內(nèi)被便捷地獲取和傳播,同時(shí)具有出色的使用體驗(yàn),下面這篇文章主要給大家介紹了關(guān)于微信小程序web-view環(huán)境下H5跳轉(zhuǎn)小程序頁(yè)面方法的相關(guān)資料,需要的朋友可以參考下2022-08-08