微信小程序實現文字長按復制與一鍵復制功能全過程

一、不引入外部組件的實現方式

 <!-- index.wxml -->
<view>
  <!-- 長按復制 -->
  <view bindlongtap="copyText" data-key="{{item.cdkey}}">{{ item.cdkey }}</view>
  <text bindlongtap="copyText" data-key="{{item.cdkey}}">{{ item.cdkey }}</text>
   <!-- 一鍵復制 -->
  <view bindtap="copyText" data-key="{{item.cdkey}}" > 復制 </view>
</view>
  • 長按復制 可利用 bindlongtap 方法,手指長按 500ms 之後觸發事件。
  • 一鍵復制 可利用 bindtap 方法,點擊立即觸發事件。
// index.js
 copyText(e) {
    let key = e.currentTarget.dataset.key;
    wx.setClipboardData({ //設置系統剪貼板的內容
      data: key,
      success(res) {
        console.log(res, key);
        wx.getClipboardData({ // 獲取系統剪貼板的內容
          success(res) {
            wx.showToast({
              title: '復制成功',
            })
          }
        })
      }
    })
  }

註:樣式可自行添加適合的樣式

效果:

二、引入外部組件的實現方式

select-text

可選文本組件。該組件有兩種使用模式:長按出現選區,與瀏覽器默認效果一致;長按出現復制按鈕,點擊復制拷貝全部內容至剪貼板,常見於聊天對話框等場景。

需註意的時,為實現點擊其它區域隱藏復制按鈕,開發者可在頁面最外層監聽 tap 事件,並將 evt 對象賦值給 on-document-tap。

安裝

npm install @miniprogram-component-plus/select-text

在頁面 page.json 中

// page.json
{
    "usingComponents": {
        "mp-select-text": "@miniprogram-component-plus/select-text"
    }
}

在頁面index.wxml中

<view bind:tap="handleTap">
  <view class="demo-block">
    <block wx:for="{{arr}}" wx:key="placement">
      <view class="list-item">
        <mp-select-text 
          show-copy-btn 
          placement="{{item.placement}}" 
          value="{{item.value}}" 
          data-id="{{index}}" 
          bindcopy="onCopy"
          on-document-tap="{{evt}}"
        >
        </mp-select-text>
      </view>
    </block>
    <view class="list-item">
      <mp-select-text value="默認的長按效果與瀏覽器一致"></mp-select-text>
    </view>
  </view>
</view>

效果

具體實現請參考:select-text組件

趕快去試試吧~

總結

到此這篇關於微信小程序實現文字長按復制與一鍵復制功能的文章就介紹到這瞭,更多相關微信小程序文字長按復制與一鍵復制內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: