uniapp的H5实现图片长按保存

实现图片预览

使用uniapp的api实现图片预览,可以缩放,关闭等操作

javascript 复制代码
uni.previewImage({
  urls:[imageUrl],
  success:()=>{
    this.controllTouch();
  }
})

imageUrl是图片地址,如https://www.111.com/abc/image.png

urls是字符串数组,用来预览图片

因为app可以使用对应的图片下载保存,这里就不多说了,主要讲的是在H5实现图片预览保存功能

长按图片显示保存弹框

因为H5无法实现长按显示弹框所以,要自己实现这个功能。

1、在图片开始预览时,加上事件监听,手指点击和手指离开

javascript 复制代码
window.addEventListener("touchstart",fnTouchStart,true);
window.addEventListener("touchend",fnTouchEnd,true);

其中touchstart和touchend是手指开始和离开的监听名字,第二个参数是监听到手指开始和手指离开时所执行的函数。

2、编写手指开始接触屏幕和手指离开时的函数

2、1手指开始接触屏幕

因为在预览时会有两个手指放大缩小图片,单击图片关闭预览的操作,所以需要对这两种情况进行判断。

当监测到屏幕上有两个手指时,不会进行保存图片提示,一个手指长按时会出现提示

其中有几个手指接触屏幕,会体现在事件监听的回调函数的参数中(e.touches.length),长度为多少就表示有多少个手指在接触屏幕。

2、2手指离开屏幕

在手指离开屏幕时,也会有对应的回调函数表示(e.touches.length),为0表示有一根手指离开屏幕。

2、3实现1秒后,长按提示

使用定时器完成,每次监测到手指点击屏幕时清空定时器,只有在长按1秒后离开屏幕,才会执行定时器里面的内容。

showDownImage 是控制弹框的显示和隐藏,后面有作用

javascript 复制代码
// 触碰屏幕控制
controllTouch(){
  let flag = false;
  let timeEvent = null;
  const fnTouchStart = (e) => {
    clearTimeout(timeEvent)
    flag = false;
    // 判断按住的时间是否超过1秒
    timeEvent = setTimeout(()=>{
      if(e.touches.length == 1){
        flag = true;
      }else if(e.touches.length == 2){
        flag = false;
      }
    },1000)
  }
  const fnTouchEnd = (e) => {
    if(e.touches.length == 0 && flag){
      this.showDownImage = true;
      flag = false;
    }else{
      //如果为单击事件,做对应的处理
       if(!this.showDownImage){
          this.closeControllTouch(fnTouchStart,fnTouchEnd,timeEvent);
       }
    }
  }
  window.addEventListener("touchstart",fnTouchStart,true);
  window.addEventListener("touchend",fnTouchEnd,true);
},

2、4为什么不适用匿名函数实现事件监听?

因为使用匿名函数后,无法对匿名函数进行去掉监听的操作。加入使用以下方法对点击事件进行监听

javascript 复制代码
window.addEventListener("touchstart",(e)=>{
  console.log(e);
},true);

后续无法拿到上面事件的函数,进行销毁事件监听处理。

3、为单击事件时,关闭预览,去掉事件监听

在上述代码中,使用了非匿名函数形式的事件监听,在这里对移除事件监听,防止在其他页面也显示弹框,同时清理定时器。

javascript 复制代码
closeControllTouch(fnTouchStart,fnTouchEnd,timeEvent){
    window.removeEventListener("touchstart",fnTouchStart,true);
    window.removeEventListener("touchend",fnTouchEnd,true);
    clearTimeout(timeEvent);
},

4、showDownImage 展示弹框

当判断是长按图片时,手指离开屏幕,出现弹框,使用了uview的模态框实现

javascript 复制代码
<u-modal :show="showDownImage"
        class="comfirm-modal"
        title="是否保存图片"
        width="560rpx"
        confirmColor="#009BF3"
        :showCancelButton="true"
        confirmText="确认"
        @confirm="downLoad"
        @cancel="showDownImage = false"
 >
 </u-modal>

@confirm="downLoad"是点击确定时,执行函数downLoad下载图片

javascript 复制代码
downLoad() {
        const url = '';//你要下载的图片地址
         var xhr = new XMLHttpRequest();
         xhr.open('get', url, true);
         xhr.responseType = 'blob';
         xhr.onload = ()=>{
           if (xhr.status === 200) {
             console.log(xhr)
             var blobUrl = new Blob([xhr.response]);
             const link = document.createElement('a');
             link.style.display = 'none';
             var urlObject = window.URL.createObjectURL(blobUrl);
             link.href = urlObject;
             link.download = url;
             document.body.appendChild(link);
             link.click();
             document.body.removeChild(link);
           }
         }
         xhr.send();
         this.showDownImage = false;
        this.closePreviewImage();
      },

下载完成图片之后,关闭模态框,事件监听,操作完成!!!

这是实习期间碰到的问题,希望大佬指正

相关推荐
Sailing1 分钟前
Grafana-mcp-analyzer:基于 MCP 的轻量 AI 分析监控图表的运维神器!
前端·node.js·mcp
阿山同学.21 分钟前
AWS 亚马逊 S3存储桶直传 前端demo 复制即可使用
前端·javascript·aws
Jolyne_29 分钟前
grid 实现完美的水平铺满、间隔一致的自适应布局
前端·css
西洼工作室33 分钟前
【解决导航栏字体图标渲染导致文本闪烁问题】采用腾讯视频的解决方案
前端·css·css3
WindrunnerMax41 分钟前
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
前端·架构·github
CodeSheep1 小时前
宇树科技,改名了!
前端·后端·程序员
Hilaku1 小时前
为什么我们用了 Vite 还是构建慢?——真正的优化在这几步
前端·javascript·vite
XI锐真的烦1 小时前
横向对比npm和yarn
前端·npm·node.js
国家不保护废物1 小时前
🧩 React 组件化进阶:像乐高大师一样搭建你的应用世界!
前端·react.js·ai编程
TimelessHaze1 小时前
从"切图崽"到前端工程师:React 到底是个啥?🚀
前端·react.js·ai编程