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

vue使用自定義指令實(shí)現(xiàn)一鍵復(fù)制功能

 更新時(shí)間:2024年09月10日 12:02:29   作者:Frilled Lizard  
在Vue中,通過(guò)自定義指令v-copy和document.execCommand方法,可以實(shí)現(xiàn)點(diǎn)擊按鈕復(fù)制內(nèi)容到剪貼板的功能,適用于處理長(zhǎng)文本或多行文本的復(fù)制需求,而readonly屬性可避免內(nèi)容被修改和移動(dòng)設(shè)備上的虛擬鍵盤(pán)干擾,感興趣的朋友一起看看吧

1.使用document.execCommand(棄用)

import { Message } from 'ant-design-vue';
const vCopy = { //
  /*
    bind 鉤子函數(shù),第一次綁定時(shí)調(diào)用,可以在這里做初始化設(shè)置
    el: 作用的 dom 對(duì)象
    value: 傳給指令的值,也就是我們要 copy 的值
  */
  bind(el, { value }) {
    el.$value = value; // 用一個(gè)全局屬性來(lái)存?zhèn)鬟M(jìn)來(lái)的值,因?yàn)檫@個(gè)值在別的鉤子函數(shù)里還會(huì)用到
    el.handler = () => {
      if (!el.$value) {
      // 值為空的時(shí)候,給出提示,我這里的提示是用的 ant-design-vue 的提示,你們隨意
        Message.warning('無(wú)復(fù)制內(nèi)容');
        return;
      }
      // 動(dòng)態(tài)創(chuàng)建 textarea 標(biāo)簽
      const textarea = document.createElement('textarea');
      // 將該 textarea 設(shè)為 readonly 防止 iOS 下自動(dòng)喚起鍵盤(pán),同時(shí)將 textarea 移出可視區(qū)域
      textarea.readOnly = 'readonly';
      textarea.style.position = 'absolute';
      textarea.style.left = '-9999px';
      // 將要 copy 的值賦給 textarea 標(biāo)簽的 value 屬性
      textarea.value = el.$value;
      // 將 textarea 插入到 body 中
      document.body.appendChild(textarea);
      // 選中值并復(fù)制
      textarea.select();
      // textarea.setSelectionRange(0, textarea.value.length);
      const result = document.execCommand('copy');
      if (result) {
        Message.success('復(fù)制成功');
      }
      document.body.removeChild(textarea);
    };
    // 綁定點(diǎn)擊事件,就是所謂的一鍵 copy 啦
    el.addEventListener('click', el.handler);
  },
  // 當(dāng)傳進(jìn)來(lái)的值更新的時(shí)候觸發(fā)
  componentUpdated(el, { value }) {
    el.$value = value;
  },
  // 指令與元素解綁的時(shí)候,移除事件綁定
  unbind(el) {
    el.removeEventListener('click', el.handler);
  },
};
export default vCopy;
<template>
  <div>
    <input v-model="text" placeholder="輸入要復(fù)制的內(nèi)容" />
    <button v-copy="text">點(diǎn)擊復(fù)制</button>
  </div>
</template>
<script>
import vCopy from './directives';
export default {
  data () {
    return {
      text: '這是要復(fù)制的內(nèi)容'  // 默認(rèn)的復(fù)制內(nèi)容
    };
  },
  directives: {
    copy: vCopy
  }
};
</script>
  • 自定義指令 v-copy 綁定到按鈕上,點(diǎn)擊按鈕時(shí)會(huì)復(fù)制綁定的內(nèi)容。
  • el.$value 保存了要復(fù)制的內(nèi)容,在每次點(diǎn)擊時(shí)通過(guò) document.execCommand(‘copy’) 復(fù)制到剪貼板。
  • 當(dāng)輸入框內(nèi)容變化時(shí),componentUpdated 鉤子會(huì)更新復(fù)制的內(nèi)容。

execCommand 是一種用于執(zhí)行與用戶操作相關(guān)的命令的方法,主要用于在文檔上執(zhí)行剪貼板操作(如復(fù)制、剪切、粘貼)或格式化操作(如加粗、斜體、下劃線)。還可以使用:“copy”、“cut”、“paste”、“bold”、“italic”

textarea標(biāo)簽:

  • 支持選中和復(fù)制操作:textarea 標(biāo)簽的內(nèi)容可以被瀏覽器原生地選中,并且它能夠被復(fù)制到剪貼板。復(fù)制操作依賴(lài)于選中文本,而 textarea 和 input 元素是 HTML 中可以輕松選中文本內(nèi)容的表單元素。雖然 input 標(biāo)簽也可以用于復(fù)制文本,但相比于 textarea,input 標(biāo)簽有一些局限性,特別是在處理較長(zhǎng)文本或多行文本時(shí)。
  • textarea 標(biāo)簽支持 readonly 屬性,可以確保它的內(nèi)容在被復(fù)制之前不會(huì)被修改。將 textarea 設(shè)置為 readonly 能避免在移動(dòng)設(shè)備上點(diǎn)擊時(shí)喚起虛擬鍵盤(pán),避免不必要的用戶干擾。

2.Clipboard API

Clipboard API 是一個(gè)現(xiàn)代的 Web API,用于在網(wǎng)頁(yè)上執(zhí)行剪貼板操作(如復(fù)制和粘貼)。與 document.execCommand 不同,Clipboard API 提供了更現(xiàn)代的異步接口,并且支持在 HTTPS 頁(yè)面上執(zhí)行這些操作以確保安全性。
Clipboard API 的方法返回一個(gè) Promise,這意味著你可以使用 then 和 catch 方法來(lái)處理成功和失敗的情況。

實(shí)現(xiàn)一鍵粘貼的功能:

使用 navigator.clipboard.readText() 方法從剪貼板讀取文本:

let vCopy = {
  bind (el, { value }) {
    el.$value = value;
    el.handler = async () => {
      if (!el.$value) {
        console.log('沒(méi)有要復(fù)制的內(nèi)容');
        return;
      }
      try {
        // 直接使用 Clipboard API 復(fù)制
        await navigator.clipboard.writeText(el.$value);
        console.log('復(fù)制成功');
      } catch (err) {
        console.error('復(fù)制失敗', err);
      }
    };
    // 監(jiān)聽(tīng)點(diǎn)擊事件
    el.addEventListener('click', el.handler);
  },
  componentUpdated (el, { value }) {
    el.$value = value;
  },
  unbind (el) {
    el.removeEventListener('click', el.handler);
  }
};
export default vCopy;
<template>
  <div>
    <input v-model="text" placeholder="輸入要復(fù)制的內(nèi)容" />
    <button v-copy="text">點(diǎn)擊復(fù)制</button>
  </div>
</template>
<script>
import vCopy from './directives';
export default {
  data () {
    return {
      text: '這是要復(fù)制的內(nèi)容'  // 默認(rèn)的復(fù)制內(nèi)容
    };
  },
  directives: {
    copy: vCopy
  }
};
</script>

navigator 是 window 對(duì)象的一個(gè)屬性,提供了有關(guān)用戶瀏覽器的信息和一些特定的功能。

主要功能:

  • 提供有關(guān)用戶代理(瀏覽器)和操作系統(tǒng)的信息。
  • 提供瀏覽器的語(yǔ)言設(shè)置和在線狀態(tài)等信息。提供對(duì)剪貼板操作、地理位置、媒體設(shè)備等現(xiàn)代瀏覽器功能的訪問(wèn)。
  • 拓展: 使用 navigator.clipboard.writeText() 方法將文本寫(xiě)入剪貼板:
<template>
  <div>
    <input v-model="text" placeholder="輸入要復(fù)制的內(nèi)容" />
    <button @click="copyToClipboard">點(diǎn)擊復(fù)制</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      text: '默認(rèn)要復(fù)制的內(nèi)容'
    };
  },
  methods: {
    copyToClipboard() {
      navigator.clipboard.writeText(this.text).then(() => {
        console.log('文本已成功復(fù)制到剪貼板');
      }).catch(err => {
        console.error('復(fù)制失敗', err);
      });
    }
  }
};
</script>

到此這篇關(guān)于vue使用自定義指令實(shí)現(xiàn)一鍵復(fù)制的文章就介紹到這了,更多相關(guān)vue一鍵復(fù)制內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue編譯器解析compile源碼解析

    Vue編譯器解析compile源碼解析

    這篇文章主要為大家介紹了Vue編譯器解析compile源碼解析示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vue-router 2.0 跳轉(zhuǎn)之router.push()用法說(shuō)明

    vue-router 2.0 跳轉(zhuǎn)之router.push()用法說(shuō)明

    這篇文章主要介紹了vue-router 2.0 跳轉(zhuǎn)之router.push()用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • 在vue項(xiàng)目中引用Iview的方法

    在vue項(xiàng)目中引用Iview的方法

    iView 是一套基于 Vue.js 的開(kāi)源 UI 組件庫(kù),主要服務(wù)于 PC 界面的中后臺(tái)產(chǎn)品。這篇文章主要介紹了在vue項(xiàng)目中引用Iview的方法,需要的朋友可以參考下
    2018-09-09
  • vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理

    vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理

    這篇文章主要為大家介紹了vue實(shí)現(xiàn)前端按鈕組件權(quán)限管理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • axios在Vue3中的使用實(shí)例代碼

    axios在Vue3中的使用實(shí)例代碼

    Axios是一個(gè)基于Promise的HTTP客戶端,用于瀏覽器和Node.js,這篇文章主要介紹了axios在Vue3中的使用,需要的朋友可以參考下
    2023-07-07
  • vue插件draggable實(shí)現(xiàn)拖拽移動(dòng)圖片順序

    vue插件draggable實(shí)現(xiàn)拖拽移動(dòng)圖片順序

    這篇文章主要為大家詳細(xì)介紹了vue插件draggable實(shí)現(xiàn)拖拽移動(dòng)圖片順序,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • 基于vue+face-api.js實(shí)現(xiàn)前端人臉識(shí)別功能

    基于vue+face-api.js實(shí)現(xiàn)前端人臉識(shí)別功能

    基于face-api.js要實(shí)現(xiàn)人臉識(shí)別功能,首先要將自己需要的模型文件下載保存在靜態(tài)目錄下,可以通過(guò)cdn的方式在index.html中引入face-api.js,本文給大家介紹vue+face-api.js實(shí)現(xiàn)前端人臉識(shí)別功能,感興趣的朋友一起看看吧
    2023-12-12
  • vue利用openlayers實(shí)現(xiàn)動(dòng)態(tài)軌跡

    vue利用openlayers實(shí)現(xiàn)動(dòng)態(tài)軌跡

    這篇文章主要為大家介紹了vue利用openlayers實(shí)現(xiàn)動(dòng)態(tài)軌跡,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • Vuerouter的beforeEach與afterEach鉤子函數(shù)的區(qū)別

    Vuerouter的beforeEach與afterEach鉤子函數(shù)的區(qū)別

    本文詳細(xì)的介紹了Vuerouter的beforeEach與afterEach鉤子函數(shù)的區(qū)別和使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • 深入理解Vue keep-alive及實(shí)踐總結(jié)

    深入理解Vue keep-alive及實(shí)踐總結(jié)

    這篇文章主要介紹了深入理解Vue keep-alive及實(shí)踐總結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08

最新評(píng)論