Vue實現(xiàn)獲取剪切板內(nèi)容的兩種方法
1.說明
在系統(tǒng)中的畫面或者時外部文件中進行拷貝處理后,在頁面中可以獲取剪切板的內(nèi)容。
2.示例
方式①(直接獲取)
// 異步函數(shù)獲取剪切板內(nèi)容
async function getClipboardContent(ev: any) {
try {
ev.preventDefault()
const clipboardText = await navigator.clipboard.readText();
const str = clipboardText.split(' ')
str.forEach(item => {
if (item) {
data.value.push({name: item})
}
})
// 處理剪切板內(nèi)容
console.log(str);
} catch (err) {
console.error('Failed to read clipboard contents: ', err);
return null;
}
}
點擊頁面中的按鈕,觸發(fā)上述方法,通過navigator.clipboard.readText()方法,獲取剪切板的內(nèi)容。使用這個方法出現(xiàn)這樣的問題,當(dāng)從系統(tǒng)的頁面中拷貝內(nèi)容時,通過上述方法可以直接讀取剪切板的內(nèi)容,但是從系統(tǒng)外部的文件中拷貝內(nèi)容時,點擊頁面的按鈕觸發(fā)這個方法時,會出現(xiàn)一個粘貼按鈕,或者操作提示,只有再次點擊或者允許進行操作時,才能獲取剪切板的內(nèi)容,這是瀏覽器的安全策略導(dǎo)致的。
方式②(間接獲取)
拷貝內(nèi)容后,在頁面中設(shè)置一個輸入框,現(xiàn)將拷貝的內(nèi)容粘貼到輸入框中,然后獲取輸入框的值從而獲取拷貝的內(nèi)容。
<a-row :gutter="3" style="height: 30px">
<a-col :span="22">
<a-input v-model="pasteValue" placeholder="請粘貼要生成的內(nèi)容"/>
</a-col>
<a-col :span="1">
<a-button @click="setData">
<template #icon>
<icon-copy/>
</template>
</a-button>
</a-col>
</a-row>
const setData = () => {
const str = pasteValue.value.split(' ')
str.forEach(item => {
if (item) {
data.value.push({name: item})
}
})
pasteValue.value = ""
}
獲取拷貝的內(nèi)容通過空格進行分割,從而獲取拷貝的數(shù)據(jù)列表。
3.總結(jié)
navigator.clipboard 的說明
navigator.clipboard 是一個 Web API,允許開發(fā)者訪問用戶的剪貼板內(nèi)容,主要用于復(fù)制和粘貼操作。這個接口提供了一些異步方法,能夠安全地讀寫剪貼板數(shù)據(jù)。
writeText(text)
描述: 將文本寫入剪貼板。
參數(shù): text - 要復(fù)制的字符串。
返回值: 返回一個 Promise,在成功復(fù)制后解決。
navigator.clipboard.writeText('Hello, World!')
.then(() => {
console.log('文本已復(fù)制到剪貼板!');
})
.catch(err => {
console.error('復(fù)制失敗: ', err);
});readText()
描述: 從剪貼板讀取文本。
返回值: 返回一個 Promise,解決為剪貼板中的文本。
navigator.clipboard.readText()
.then(text => {
console.log('剪貼板中的文本: ', text);
})
.catch(err => {
console.error('讀取失敗: ', err);
});
使用注意事項
安全性: 訪問剪貼板需要在 HTTPS 環(huán)境中進行,或在 localhost 上。
用戶交互: 大多數(shù)瀏覽器要求在用戶的交互(如點擊按鈕)后才能執(zhí)行剪貼板操作,以防止濫用。
詳細(xì)示例
<button id="copyButton">復(fù)制文本</button>
<button id="pasteButton">粘貼文本</button>
<p id="output"></p>
<script>
document.getElementById('copyButton').addEventListener('click', () => {
navigator.clipboard.writeText('Hello, Clipboard!')
.then(() => {
console.log('文本已復(fù)制!');
});
});
document.getElementById('pasteButton').addEventListener('click', () => {
navigator.clipboard.readText()
.then(text => {
document.getElementById('output').textContent = text;
});
});
</script>到此這篇關(guān)于Vue實現(xiàn)獲取剪切板內(nèi)容的兩種方法的文章就介紹到這了,更多相關(guān)Vue獲取剪切板內(nèi)容內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue elementui表格獲取某行數(shù)據(jù)(slot-scope和selection-change方法使用)
這篇文章主要介紹了vue elementui表格獲取某行數(shù)據(jù)(slot-scope和selection-change方法使用),本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-01-01
vue.js動畫中的js鉤子函數(shù)的實現(xiàn)
這篇文章主要介紹了vue.js動畫中的js鉤子函數(shù)的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-07
vue中html2canvas給指定區(qū)域添加滿屏水印
本文主要介紹了vue中html2canvas給指定區(qū)域添加滿屏水印,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-11-11
如何基于uniapp開發(fā)android播放webrtc流詳解
這篇文章主要介紹了在uniapp中播放RTSP和WebRTC協(xié)議流的區(qū)別,以及如何封裝WebrtcVideo組件和音視頻實時通訊的實現(xiàn),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-02-02

