Vue實現(xiàn)獲取剪切板內(nèi)容的兩種方法
1.說明
在系統(tǒng)中的畫面或者時外部文件中進(jìn)行拷貝處理后,在頁面中可以獲取剪切板的內(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)一個粘貼按鈕,或者操作提示,只有再次點擊或者允許進(jì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)容通過空格進(jìn)行分割,從而獲取拷貝的數(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)境中進(jì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-01vue.js動畫中的js鉤子函數(shù)的實現(xiàn)
這篇文章主要介紹了vue.js動畫中的js鉤子函數(shù)的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-07vue中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