分享手机端复制链接及成功后弹窗提示的2种方法

直接上代码了

      <!-- 底部分享 -->
      <div class="shareBox">
        <div class="copyLink">
          <button @click="copyLink(qrCodeText)" class="clickBtn">
            <span><img src="@/assets/common/copyLink.png" alt="" /></span
            >复制链接
          </button>
       </div>

 方法一:自己写一个弹窗的样式获取dom控制显示和隐藏

   //点击按钮复制链接
    copyLink(val) {
      let url = val; // 后台接口返回的链接地址
      let inputNode = document.createElement("input"); // 创建input
      inputNode.setAttribute("readonly", "readonly"); //设置只读,否则移动端使用复制功能时会造成软键盘自动弹起
      inputNode.value = url; // 赋值给 input 值
      document.body.appendChild(inputNode); // 插入进去
      inputNode.select(); // 选择对象
      document.execCommand("Copy"); // 原生调用执行浏览器复制命令
      inputNode.className = "oInput";
      inputNode.style.display = "none"; // 将input隐藏
      document.getElementById("message").style.display = ""; //复制后弹出-自己写一个弹窗的样式
      //1.5秒后自动隐藏
      setTimeout(
        "document.getElementById('message').style.display='none'",
        1500
      );
     
      inputNode.remove(); //将input销毁

     
    },

 

 弹窗效果展示

方法二:直接用window.alert()方法

   copyLink(val) {
      console.log(val, "复制链接");
      let url = val; // 后台接口返回的链接地址
      let inputNode = document.createElement("input"); // 创建input
      inputNode.setAttribute("readonly", "readonly"); //设置只读,否则移动端使用复制功能时会造成软键盘自动弹起
      inputNode.value = url; // 赋值给 input 值
      document.body.appendChild(inputNode); // 插入进去
      inputNode.select(); // 选择对象
      document.execCommand("Copy"); // 原生调用执行浏览器复制命令
      inputNode.className = "oInput";
      inputNode.style.display = "none"; // 将input隐藏
     
      // 去掉ios(h5)中alert弹框里面的网址
       window.alert = function (name) {
         const iframe = document.createElement("IFRAME");
         iframe.style.display = "none";
         iframe.setAttribute("src", "data:text/plain,");
         document.documentElement.appendChild(iframe);
         window.frames[0].window.alert(name);
         iframe.parentNode.removeChild(iframe);
       };

      window.alert("已复制到粘贴板");
      inputNode.remove(); //将input销毁  
    },

弹窗效果展示

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值