app内嵌H5调用分享

最近产品提出了一个需求:我们在合作方的app中提供的部分页面中增加分享页面,具体要求是在3个二维码推广页面调用app的分享接口,分享方式有3种,分别是点击”分享链接“按钮调起分享,点击”分享图片“按钮调起分享,以及长按保存页面。

二维码的推广页面是由一张背景图和一张动态生成的二维码图片组成。

点击”分享链接“调起分享非常简单,就不再赘述了。

点击”分享图片“按钮进行分享,合作方app接口要求传入进行分享的图片地址。这就要求分享出去的图片先要存在图片服务器中,但是每个用户的分享二维码是不同的,我们不可能为每个用户画一张分享图片,再存到服务器中。经过一番搜索,最终决定由前端对分享页面截图,上传服务器,再把返回的图片地址传给app。

前端截图主要用到2个库,html2canvas 和canvas2image。顾名思义,先把页面元素输出到canvas上,再把canvas转成图片上传到服务器。

  function createPicture() {
    var shareButton = document.querySelector(".share-button"); // 获取不希望出现在截图中的DOM,然后隐藏,等图片生成完毕,再恢复显示
    var tip = document.querySelector(".tip");
    shareButton.style.display = "none";
    tip.style.display = "none";
    html2canvas(document.body).then(function (canvas) {
      var img = Canvas2Image.convertToPNG(canvas, canvas.width, canvas.height);
      var base64 = img.src;
      var byteString = atob(base64.split(",")[1]); //base64 解码
      var arrayBuffer = new ArrayBuffer(byteString.length); //创建缓冲数组
      var intArray = new Uint8Array(arrayBuffer); //创建视图
      for (var i = 0; i < byteString.length; i++) {
        intArray[i] = byteString.charCodeAt(i);
      }
      var b = new Blob([intArray], {type: "image/png"});
      b.lastModifiedDate = new Date();
      b.name = Date.now() + ".png";
      var file = new FormData();
      file.append("upfile", b, b.name);
      shareButton.style.display = "flex";
      tip.style.display = "flex";
      return file;
    });
  }// 函数返回一个文件对象,把文件对象上传服务器即可

”长按保存“的原理也类似,首先背景图和二维码都需要是dom元素的background-image,因为移动端H5是没有长按事件的,所以使用touch事件模拟。如果把把背景图、二维码图设为img标签,再app也设定捕获屏幕的长按事件的情况下,H5页面捕获touch事件同时,app也会捕获长按事件,造成调起2次事件处理。设为background-image可以避免app捕获长按事件。长按保存的具体原理是,touchstart事件处理函数:调用setTimeout设定1-2秒后调用截图函数并上传服务器,并把返回的图片地址传给app,touchmove,touchend事件处理函数:使用clearTimeout取消定时器。这样只有一直按着不动,经过预定的时间后,调起真正的时间处理函数,手指移动或者离开屏幕清除定时间,真正的事件处理函数不会执行。

转载于:https://www.cnblogs.com/KlllB/p/11047400.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
随着互联网的发展,移动互联网的普及,手机APP已成为人们使用最多的移动终端产品之一。随着越来越多的APP应用的涌现,越来越多的APP需要内嵌H5页面WebView进行网页的展示和交互。WebView是一种可在应用程序中嵌入Web页面的控件,可以用来显示来自互联网上的Web页面。它可以实现在应用中展示网页或在线功能,解决一些本地应用无法实现的功能。下面,我们分别从用户、开发者两个方面来探讨APP内嵌H5页面WebView的优缺点。 一、用户方面: 优点: 1.节省时间:在APP中直接查看嵌入的网页,省去了用户手动打开浏览器输入网址的步骤; 2.良好的用户体验:页面加载速度相对较快,而且对主应用对内存占用少,不影响其他应用的使用; 3.方便分享:在WebView中打开的网页可以长按复制网址链接,方便分享给其它用户; 4.强大的交互能力:在APP中嵌入H5页面,拓展了应用的交互能力。 缺点: 1.便捷性带来的安全隐患:一些App会在内嵌H5页面中嵌入第三方广告,导致用户隐私泄露; 2.缺乏统一标准:因为浏览器的内核和引擎都是不同的,所以在不同的WebView中,同一网页的显示效果和交互体验可能会有差异。 二、开发者方面: 优点: 1.拓展应用功能:借助WebView内嵌H5页面,应用的功能可以得到极大的拓展; 2.代码复用:WebView可以实现HTML、CSS等内容的兼容,减轻了移动开发者负担; 3.节省开发成本:相对于开发单独的H5 APP内嵌方式更为灵活,可以适用于不同场景和需求。 缺点: 1.不支持多线程:WebView在JS调用本地方法的时候是在同一线程下执行的,如果WebView的内容较为复杂,可能会导致主线程卡顿; 2.性能问题:在内存管理、布局排版等方面还不如原生应用; 3.浏览器兼容性:WebView的内核并没有得到很好的统一,不同的WebView之间有兼容性问题,会导致页面显示和交互问题; 4.安全问题:WebView加载HTML页面时容易受到跨站脚本(XSS)和恶意代码注入等安全漏洞的攻击。为此,开发者应该加强前端页面安全防范,对浏览器缓存和Cookie进行管理并开启CSP(内容安全策略)。 综合来看,在APP内嵌H5页面WebView上,开发者需要在开发时注意安全方面的问题,同时还需要加强对WebView性能和兼容性的了解和优化。用户便捷性和良好的用户体验,也需要开发者在开发时重视。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值