Vue實(shí)現(xiàn)獲取剪切板內(nèi)容的兩種方法
1.說(shuō)明
在系統(tǒng)中的畫面或者時(shí)外部文件中進(jìn)行拷貝處理后,在頁(yè)面中可以獲取剪切板的內(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; } }
點(diǎn)擊頁(yè)面中的按鈕,觸發(fā)上述方法,通過(guò)navigator.clipboard.readText()方法,獲取剪切板的內(nèi)容。使用這個(gè)方法出現(xiàn)這樣的問(wèn)題,當(dāng)從系統(tǒng)的頁(yè)面中拷貝內(nèi)容時(shí),通過(guò)上述方法可以直接讀取剪切板的內(nèi)容,但是從系統(tǒng)外部的文件中拷貝內(nèi)容時(shí),點(diǎn)擊頁(yè)面的按鈕觸發(fā)這個(gè)方法時(shí),會(huì)出現(xiàn)一個(gè)粘貼按鈕,或者操作提示,只有再次點(diǎn)擊或者允許進(jìn)行操作時(shí),才能獲取剪切板的內(nèi)容,這是瀏覽器的安全策略導(dǎo)致的。
方式②(間接獲取)
拷貝內(nèi)容后,在頁(yè)面中設(shè)置一個(gè)輸入框,現(xiàn)將拷貝的內(nèi)容粘貼到輸入框中,然后獲取輸入框的值從而獲取拷貝的內(nèi)容。
<a-row :gutter="3" style="height: 30px"> <a-col :span="22"> <a-input v-model="pasteValue" placeholder="請(qǐng)粘貼要生成的內(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)容通過(guò)空格進(jìn)行分割,從而獲取拷貝的數(shù)據(jù)列表。
3.總結(jié)
navigator.clipboard 的說(shuō)明
navigator.clipboard 是一個(gè) Web API,允許開發(fā)者訪問(wèn)用戶的剪貼板內(nèi)容,主要用于復(fù)制和粘貼操作。這個(gè)接口提供了一些異步方法,能夠安全地讀寫剪貼板數(shù)據(jù)。
writeText(text)
描述: 將文本寫入剪貼板。
參數(shù): text - 要復(fù)制的字符串。
返回值: 返回一個(gè) Promise,在成功復(fù)制后解決。
navigator.clipboard.writeText('Hello, World!') .then(() => { console.log('文本已復(fù)制到剪貼板!'); }) .catch(err => { console.error('復(fù)制失敗: ', err); });
readText()
描述: 從剪貼板讀取文本。
返回值: 返回一個(gè) Promise,解決為剪貼板中的文本。
navigator.clipboard.readText() .then(text => { console.log('剪貼板中的文本: ', text); }) .catch(err => { console.error('讀取失敗: ', err); });
使用注意事項(xiàng)
安全性: 訪問(wèn)剪貼板需要在 HTTPS 環(huán)境中進(jìn)行,或在 localhost 上。
用戶交互: 大多數(shù)瀏覽器要求在用戶的交互(如點(diǎn)擊按鈕)后才能執(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實(shí)現(xiàn)獲取剪切板內(nèi)容的兩種方法的文章就介紹到這了,更多相關(guān)Vue獲取剪切板內(nèi)容內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue elementui表格獲取某行數(shù)據(jù)(slot-scope和selection-change方法使用)
這篇文章主要介紹了vue elementui表格獲取某行數(shù)據(jù)(slot-scope和selection-change方法使用),本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01Vue3項(xiàng)目中reset.scss模板使用導(dǎo)入
這篇文章主要為大家介紹了Vue3項(xiàng)目中reset.scss模板使用導(dǎo)入示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09uniapp仿微信聊天界面效果實(shí)例(vue3組合式版本)
這篇文章主要介紹了uniapp仿微信聊天界面的相關(guān)資料,這里提及了一個(gè)時(shí)間工具包timeMethod.js,該工具包可能提供了一系列時(shí)間處理的功能,如格式化日期、計(jì)算時(shí)間差等,以便在消息格式中正確展示時(shí)間信息,使用此類工具包可以大大提高開發(fā)效率,需要的朋友可以參考下2024-10-10vue.js動(dòng)畫中的js鉤子函數(shù)的實(shí)現(xiàn)
這篇文章主要介紹了vue.js動(dòng)畫中的js鉤子函數(shù)的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-07-07vue中html2canvas給指定區(qū)域添加滿屏水印
本文主要介紹了vue中html2canvas給指定區(qū)域添加滿屏水印,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-11-11如何基于uniapp開發(fā)android播放webrtc流詳解
這篇文章主要介紹了在uniapp中播放RTSP和WebRTC協(xié)議流的區(qū)別,以及如何封裝WebrtcVideo組件和音視頻實(shí)時(shí)通訊的實(shí)現(xiàn),文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2025-02-02vue子組件通過(guò).sync修飾符修改props屬性方式
這篇文章主要介紹了vue子組件通過(guò).sync修飾符修改props屬性方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08