升平网络

 找回密码
 立即注册

快捷登录

查看: 1334|回复: 0

微信小程序使用rich-text 里面图片预览下载问题

[复制链接]

68

主题

68

帖子

240

积分

中级会员

Rank: 3Rank: 3

积分
240
发表于 2024-5-27 09:40:25 | 显示全部楼层 |阅读模式

这是一个创建于2024-5-27 09:40的主题,其中的信息可能已经有所发展或是发生改变。

本帖最后由 A00湖北云购科技 于 2024-5-27 13:43 编辑

微信小程序使用rich-text 里面图片预览下载问题
方案:将html文本里面的图片地址保留起来,然后做一个长按/双击事件,放手后进行预览图片地址(缺点:无法确定长按的是那一张,全部展示)

  1. <view class="text-content" style="max-height: max-content;">
  2.     <!-- 双击 -->
  3.       <rich-text bindtap="doubleClick" user-select nodes="{{JournalismDetailDto.thisDetail.journalismContent}}"></rich-text>
  4.       
  5.       <!-- 长按
  6.       <rich-text data-timeStamp="" bindtouchstart="onStart" bindtouchend="onEnd" user-select nodes="{{JournalismDetailDto.thisDetail.journalismContent}}"></rich-text>
  7.   -->
  8.     </view>
复制代码

  1. //整理图片
  2. var paths = [];
  3. var idx = res.data.thisDetail.journalismContent.indexOf(`src="${app.globalData.downloadurl}/`);
  4. while (idx !== -1) {
  5.   var idx2= res.data.thisDetail.journalismContent.indexOf('>',idx); //img节点
  6.   var tempStr= res.data.thisDetail.journalismContent.substring(idx, idx2).replace('src="','');//找到地址
  7.   var idx3=tempStr.indexOf('"');//找到url地址位置
  8.   if(idx3!==-1){
  9.     var path =  tempStr.substring(0,idx3);
  10.     paths.push(path);
  11.   }
  12.   idx = res.data.thisDetail.journalismContent.indexOf(`src="${app.globalData.downloadurl}/`, idx2 + 1);
  13. }


  14. //长按操作
  15. startTime: null,
  16. endTime: null,
  17. picslist:[],//图片集合

  18. onStart: function (event) {
  19.     this.data.startTime = event.timeStamp
  20.     console.log("按下时间戳:" + this.data.startTime)
  21.   },
  22.   onEnd: function (event) {
  23.     this.data.endTime = event.timeStamp
  24.     console.log("抬起时间戳:" + this.data.endTime)

  25.     let ti = this.data.endTime - this.data.startTime
  26.     if (ti >= 1500) {
  27.       console.log("大于指定时间,开始执行对应的业务逻辑")
  28.       wx.previewImage({
  29.         urls:  this.data.picslist, // 需要预览的图片http链接列表
  30.       })
  31.     }
  32.     else {
  33.       console.log("小于指定时间,不执行操作")
  34.     }
  35.   }
复制代码

  1. //双击操作
  2.   doubleClick: function(e) {
  3.     // 获取这次点击时间
  4.     var thisTime = e.timeStamp;
  5.     // 获取上次点击时间 默认为0
  6.     var lastTime = this.data.lastTime;
  7.     // 打印这次点击时间
  8.     console.log("这次时间:" + thisTime)
  9.     console.log("上次时间:" + lastTime)
  10.     console.log(thisTime - this.data.lastTime)
  11.    
  12.     if (lastTime != 0) {
  13.       if (thisTime - this.data.lastTime < 500)
  14.         {
  15.           console.log("双击事件")
  16.           wx.previewImage({
  17.             urls:  this.data.picslist, // 需要预览的图片http链接列表
  18.           });
  19.         }
  20.     }
  21.     // 赋值
  22.     this.setData({
  23.       lastTime: thisTime
  24.     })
  25.   },
复制代码


打赏鼓励一下!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|升平网络 ( 鄂ICP备18029072号 )|网站地图

GMT+8, 2024-9-21 15:28 , Processed in 0.146973 second(s), 24 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表