欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue實(shí)現(xiàn)獲取剪切板內(nèi)容的兩種方法

 更新時(shí)間:2025年02月27日 09:13:09   作者:linab112  
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)獲取剪切板內(nèi)容的兩種方法,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,有需要的小伙伴可以了解下

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方法使用)

    這篇文章主要介紹了vue elementui表格獲取某行數(shù)據(jù)(slot-scope和selection-change方法使用),本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01
  • Vue3項(xiàng)目中reset.scss模板使用導(dǎo)入

    Vue3項(xiàng)目中reset.scss模板使用導(dǎo)入

    這篇文章主要為大家介紹了Vue3項(xiàng)目中reset.scss模板使用導(dǎo)入示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-09-09
  • uniapp仿微信聊天界面效果實(shí)例(vue3組合式版本)

    uniapp仿微信聊天界面效果實(shí)例(vue3組合式版本)

    這篇文章主要介紹了uniapp仿微信聊天界面的相關(guān)資料,這里提及了一個(gè)時(shí)間工具包timeMethod.js,該工具包可能提供了一系列時(shí)間處理的功能,如格式化日期、計(jì)算時(shí)間差等,以便在消息格式中正確展示時(shí)間信息,使用此類工具包可以大大提高開發(fā)效率,需要的朋友可以參考下
    2024-10-10
  • vue.js動(dòng)畫中的js鉤子函數(shù)的實(shí)現(xiàn)

    vue.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-07
  • vue中html2canvas給指定區(qū)域添加滿屏水印

    vue中html2canvas給指定區(qū)域添加滿屏水印

    本文主要介紹了vue中html2canvas給指定區(qū)域添加滿屏水印,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11
  • vue中echarts3.0自適應(yīng)的方法

    vue中echarts3.0自適應(yīng)的方法

    這篇文章主要介紹了vue中echarts3.0自適應(yīng),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02
  • 如何基于uniapp開發(fā)android播放webrtc流詳解

    如何基于uniapp開發(fā)android播放webrtc流詳解

    這篇文章主要介紹了在uniapp中播放RTSP和WebRTC協(xié)議流的區(qū)別,以及如何封裝WebrtcVideo組件和音視頻實(shí)時(shí)通訊的實(shí)現(xiàn),文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-02-02
  • Vue.js每天必學(xué)之Class與樣式綁定

    Vue.js每天必學(xué)之Class與樣式綁定

    這篇文章主要為大家詳細(xì)介紹了Vue.js的Class與樣式綁定,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • vue子組件通過(guò).sync修飾符修改props屬性方式

    vue子組件通過(guò).sync修飾符修改props屬性方式

    這篇文章主要介紹了vue子組件通過(guò).sync修飾符修改props屬性方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue3屬性綁定方法解析

    Vue3屬性綁定方法解析

    這篇文章主要介紹了Vue3屬性綁定方法解析,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09

最新評(píng)論