使用clipboard.js實現(xiàn)復制功能的示例代碼
最近在工作中有一個需求,就是需要使用一個按鈕實現(xiàn)相應內(nèi)容的復制。在網(wǎng)上找了很多解決方案,最后對比之下選擇了clipboard.js插件來進行實現(xiàn)。因為它不依靠flash以及其他框架,而且體積小使用簡單兼容性也好。下面簡單介紹一下它的用法。
引入插件,可以下載,也可以使用第三方cdn。
<script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/1.7.1/clipboard.min.js"></script>
對于HTML來說,我們有兩種用法。
第一種
//html部分
<input type="text" id="copyValue" />
<button type="button" data-clipboard-target='#copyValue'>復制</button>
//js部分
var clipboard = new Clipboard('button');
clipboard.on('success',function(e){
e.clearSelection();
alert('復制成功');
});
clipboard.on('error',function(e){
e.clearSelection();
alert('復制失敗');
});
說明:如果我們使用按鈕復制的是另一個元素的內(nèi)容,則我們可以使用這種方法。此時將按鈕稱為觸發(fā)元素,被復制的元素稱為目標元素。此時data-clipboard-target的值為目標元素的選擇器,而data-clipboard-target的屬性被設置在觸發(fā)元素上。new Clipboard()為實例化對象,參數(shù)可以是HTML元素,元素選擇器。有success和error兩個事件可以供我們監(jiān)聽,實現(xiàn)自己的邏輯。因為復制完成后,目標元素會處于選中狀態(tài),所以我們需要e.clearSelection()取消目標元素的選中狀態(tài)。
優(yōu)點:復制的內(nèi)容可以是動態(tài)的,目標元素的值發(fā)生變化,復制的值也發(fā)生變化。
適用場景:復制內(nèi)容可變,不固定。
第二種
//html部分
<button type="button" data-clipboard-text='復制內(nèi)容'>復制</button>
//js部分
new Clipboard('button');
說明:data-clipboard-text的值為你要復制的內(nèi)容。無目標元素,只有觸發(fā)元素。
缺點:復制的內(nèi)容是靜態(tài)的,不變的,提前設置好的。
適用場景:復制內(nèi)容固定不變
對于以上缺點,我們可以優(yōu)化如下,使之復制的內(nèi)容也是動態(tài)的。
//html部分
<input type="text" id="copyValue" />
<button type="button" id="copy">復制</button>
//js
$('#copy').on('click', function () {
var value = $('#copyValue').val();
$('#copy').attr('data-clipboard-text', value);
var clipboard = new Clipboard('#copy');
clipboard.on('success', function (e) {
alert('復制成功');
});
clipboard.on('error', function (e) {
alert('復制失敗');
});
})
接著這里曬出最常用的幾種方式,以供不時之需。
function-target
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>function-target</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<!-- 1. Define some markup -->
<button class="btn">Copy</button>
<div>hello</div>
<!-- 2. Include library -->
<script src="../dist/clipboard.min.js"></script>
<!-- 3. Instantiate clipboard -->
<script>
var clipboard = new ClipboardJS('.btn', {
target: function() {
return document.querySelector('div');
}
});
clipboard.on('success', function(e) {
//console.log(e);
alert('復制成功!')
});
clipboard.on('error', function(e) {
console.log(e);
});
</script>
</body>
</html>
function-text
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>function-text</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<!-- 1. Define some markup -->
<button class="btn">Copy</button>
<!-- 2. Include library -->
<script src="../dist/clipboard.min.js"></script>
<!-- 3. Instantiate clipboard -->
<script>
var clipboard = new ClipboardJS('.btn', {
text: function() {
return 'to be or not to be';
}
});
clipboard.on('success', function(e) {
console.log(e);
});
clipboard.on('error', function(e) {
console.log(e);
});
</script>
</body>
</html>
target-div
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>target-div</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<!-- 1. Define some markup -->
<span class="copy_content">hello 123</span>
<button class="btn" data-clipboard-action="copy" data-clipboard-target=".copy_content">Copy</button>
<!-- 2. Include library -->
<script src="../dist/clipboard.min.js"></script>
<!-- 3. Instantiate clipboard -->
<script>
var clipboard = new ClipboardJS('.btn');
clipboard.on('success', function(e) {
console.log(e);
});
clipboard.on('error', function(e) {
console.log(e);
});
</script>
</body>
</html>
target-input
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>target-input</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<!-- 1. Define some markup -->
<input id="foo" type="text" value="hello">
<button class="btn" data-clipboard-action="copy" data-clipboard-target="#foo">Copy</button>
<!-- 2. Include library -->
<script src="../dist/clipboard.min.js"></script>
<!-- 3. Instantiate clipboard -->
<script>
var clipboard = new ClipboardJS('.btn');
clipboard.on('success', function(e) {
console.log(e);
});
clipboard.on('error', function(e) {
console.log(e);
});
</script>
</body>
</html>
target-textarea
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>target-textarea</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
</head>
<body>
<!-- 1. Define some markup -->
<textarea id="bar">hello</textarea>
<button class="btn" data-clipboard-action="cut" data-clipboard-target="#bar">Cut</button>
<!-- 2. Include library -->
<script src="../dist/clipboard.min.js"></script>
<!-- 3. Instantiate clipboard -->
<script>
var clipboard = new ClipboardJS('.btn');
clipboard.on('success', function(e) {
console.log(e);
});
clipboard.on('error', function(e) {
console.log(e);
});
</script>
</body>
</html>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
JS端基于download.js實現(xiàn)圖片、視頻時直接下載而不是打開預覽
這篇文章主要介紹了JS端基于download.js實現(xiàn)圖片、視頻時直接下載而不是打開預覽,需要的朋友可以參考下2020-05-05
JavaScript求一個數(shù)組中重復出現(xiàn)次數(shù)最多的元素及其下標位置示例
這篇文章主要介紹了JavaScript求一個數(shù)組中重復出現(xiàn)次數(shù)最多的元素及其下標位置,涉及javascript數(shù)組元素遍歷、判斷、正則過濾、追加等相關操作技巧,需要的朋友可以參考下2018-07-07
javascript 正則替換 replace(regExp, function)用法
剛在弄網(wǎng)頁通過servlet返回的json數(shù)據(jù)來添加div元素,簡單研究了下replace(regExp, function)方式的function參數(shù).2010-05-05
JS自調(diào)用匿名函數(shù)具體實現(xiàn)
定義一個函數(shù)用做臨時的命名空間,在這個命名空間內(nèi)定義的變量都不會污染到全局命名空間,需要的朋友可以參考下2014-02-02

