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

vue實現(xiàn)復制文字復制圖片實例詳解

 更新時間:2023年02月23日 09:38:53   作者:元子不圓呀  
這篇文章主要為大家介紹了vue實現(xiàn)復制文字復制圖片實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

正文

復制文字和圖片是我們經(jīng)常會使用到的需求,我們這篇文章主要介紹使用navigator.clipboard.write()來實現(xiàn)復制文字和圖片。不過這個屬性是需要考慮瀏覽器的兼容性的,可以參考MDN

document.execCommand('copy')

在很久之前我們是使用document.execCommand('copy')來實現(xiàn)復制文本的,但是現(xiàn)在mdn上已經(jīng)將這個命令廢棄了。

當一個 HTML 文檔切換到設計模式時,document暴露 execCommand 方法,該方法允許運行命令來操縱可編輯內(nèi)容區(qū)域的元素。如果傳入copy命令,那么就能實現(xiàn)復制的功能。

比如像下面這樣

  // 復制文字
  copyText(link, cb) {
    let input = document.createElement('textarea');
    input.style.cssText = 'position: absolute; top: 0; left: 0; opacity: 0; z-index: -10;';
    input.value = link;
    document.body.appendChild(input);
    input.select();
    document.execCommand('copy');
    document.body.removeChild(input);
    if (typeof cb === 'function') {
      cb();
    }
  }

Clipboard

Clipboard 接口實現(xiàn)了 Clipboard API,如果用戶授予了相應的權(quán)限,其就能提供系統(tǒng)剪貼板的讀寫訪問能力。在 Web 應用程序中,Clipboard API 可用于實現(xiàn)剪切、復制和粘貼功能。

方法

Clipboard提供了以下方法,方便我們讀取剪切板的內(nèi)容。

  • read():從剪貼板讀取數(shù)據(jù)(比如圖片),返回一個 Promise對象。在檢索到數(shù)據(jù)后,promise 將兌現(xiàn)一個 ClipboardItem對象的數(shù)組來提供剪切板數(shù)據(jù)。
  • readText():從操作系統(tǒng)讀取文本;返回一個 Promise,在從剪切板中檢索到文本后,promise 將兌現(xiàn)一個包含剪切板文本數(shù)據(jù)的 DOMString
  • write(): 寫入任意數(shù)據(jù)至操作系統(tǒng)剪貼板。這是一個異步操作,在操作完成后,返回的 promise 的將被兌現(xiàn)。
  • writeText(): 寫入文本至操作系統(tǒng)剪貼板。返回一個 Promise,在文本被完全寫入剪切板后,返回的 promise 將被兌現(xiàn)。

復制文本

復制文本的方法很簡單,就是使用navigator.clipboard.writeText()方法。

具體代碼實現(xiàn)如下:

copyTextToClipboard(text) {
  return new Promise((resolve, reject) => {
    navigator.clipboard.writeText(text).then(
      () => {
        resolve(true)
      },
      () => {
        reject(new Error('復制失敗'))
      }
    )
  })
}

復制圖片

復制圖片主要用到navigator.clipboard.write()方法。 因為我們在頁面中通常是要根據(jù)一個img元素復制圖片,主要實現(xiàn)思路如下:

  • 先將img元素轉(zhuǎn)成base64
  • 再將base64轉(zhuǎn)成blob對象
  • 根據(jù)blob對象new一個ClipboardItem對象
  • 最后再根據(jù)navigator.clipboard.writeText()將內(nèi)容寫入剪貼板中

具體代碼實現(xiàn)如下:

  // 圖片元素轉(zhuǎn)base64
  getBase64Image(img) {
    let canvas = document.createElement('canvas');
    canvas.width = img.width;
    canvas.height = img.height;
    let ctx = canvas.getContext('2d');
    ctx?.drawImage(img, 0, 0, img.width, img.height);
    let dataURL = canvas.toDataURL('image/png');
    return dataURL;
  },
  // base64圖片轉(zhuǎn)為blob
  getBlobImage(dataurl) {
    let arr = dataurl.split(',');
    let mime = arr[0].match(/:(.*?);/)[1];
    let bstr = atob(arr[1]);
    let n = bstr.length;
    let u8arr = new Uint8Array(n);
    while (n--) {
      u8arr[n] = bstr.charCodeAt(n);
    }
    return new Blob([u8arr], { type: mime });
  },
  // 復制圖片
  copyImage(dom, cb) {
    let dataurl = this.getBase64Image(dom);
    let blob = this.getBlobImage(dataurl);
    navigator.clipboard.write([
      new window.ClipboardItem({
        [blob.type]: blob
      })
    ]).then(function() {
      if (typeof cb === 'function') {
        cb();
      }
    }, function() {
      console.log('圖片復制失敗!');
    });
  }

以上就是vue實現(xiàn)復制文字復制圖片實例詳解的詳細內(nèi)容,更多關于vue復制文字圖片的資料請關注腳本之家其它相關文章!

相關文章

  • vue實現(xiàn)購物車小案例

    vue實現(xiàn)購物車小案例

    這篇文章主要為大家詳細介紹了vue實現(xiàn)購物車小案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • vue 修改vant自帶的樣式過程

    vue 修改vant自帶的樣式過程

    這篇文章主要介紹了vue 修改vant自帶的樣式過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue 表情包輸入組件的實現(xiàn)代碼

    Vue 表情包輸入組件的實現(xiàn)代碼

    這篇文章主要介紹了Vue 表情包輸入組件的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • vue-video-player 斷點續(xù)播的實現(xiàn)

    vue-video-player 斷點續(xù)播的實現(xiàn)

    這篇文章主要介紹了vue-video-player 斷點續(xù)播的實現(xiàn),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • vue循環(huán)語句v-for中的元素綁定值

    vue循環(huán)語句v-for中的元素綁定值

    這篇文章主要介紹了vue循環(huán)語句v-for中的元素綁定值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • petite?vue的使用示例詳解

    petite?vue的使用示例詳解

    這篇文章主要為大家介紹了petite?vue的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 解決vue運行報錯Error:Cannot?find?module?'@vue/cli-plugin-babel'

    解決vue運行報錯Error:Cannot?find?module?'@vue/cli-plugin-b

    解決了因為版本問題在創(chuàng)建項目時出現(xiàn)的各種報錯問題,這次在運行時出現(xiàn)的問題,下面這篇文章主要給大家介紹了關于解決vue運行報錯Error:Cannot?find?module?'@vue/cli-plugin-babel'的相關資料,需要的朋友可以參考下
    2023-04-04
  • vue中el-table多級嵌套列表(菜單使用el-switch代替)

    vue中el-table多級嵌套列表(菜單使用el-switch代替)

    本文主要介紹了el-table多級嵌套列表(菜單使用el-switch代替),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • 解決Vite無法分析出動態(tài)import的類型,控制臺出警告的問題

    解決Vite無法分析出動態(tài)import的類型,控制臺出警告的問題

    這篇文章主要介紹了解決Vite無法分析出動態(tài)import的類型,控制臺出警告的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 解讀vant的Uploader上傳問題

    解讀vant的Uploader上傳問題

    這篇文章主要介紹了解讀vant的Uploader上傳問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評論