van-uploader 在app内嵌的webview中的一些坑

问题:

  1. 部分版本在ios 中没有问题,但是安卓中不触发图片选择和拍照(之前是可以的,可能是没有锁定版本,重新发版导致的)。
  2. 在ios中下拉文案是英文,html配置lang等于 zh 也没有用,ios里配置也无效。
  3. 我自己遇到的,ios中拍照上传图片点击使用图片之后会刷新整个页面。

解决方案:

  1. 安卓使用app 提供的原生方法上传图片(上传逻辑放在app完成,上传成功之后给h5 返回图片url)
    1-1:利用**@click.native** 的特性,会触发组件上传方法之前调用 clickUploader 方法,判断如果是安卓app,则阻止事件向内部传递,然后调用原生app提供的方法。
    1-2:app上传成功之后会调用前端绑定在window上的方法backImgUrlFromApp,然后把图片的url传给H5端。
    1-3:此种方法不会自动触发组件的afterRead方法了,需要自己手动调用。
    1-4:如果是在ios app中打开的H5, 则不会触发 event.preventDefault(),会走组件的触发ios上传功能
<van-uploader
   v-model="uploader1"
   max-count="1"
   :after-read="afterRead"
   upload-text="选择图片"
   @click.native="clickUploader($event, 'uploader1')"
 />
 // 上传方法
clickUploader(event, formKey) {
   if (!this[formKey].length && inAndroidApp()) {
        event.preventDefault();
        window.nativeApp.callAlbum();
        (window as any).backImgUrlFromApp= async (url: string) => {
          console.log("拿到app返回的上传图片的url", url);
          this[formKey] = [{ url }];
          this.afterRead({ filePath: url }, true);
        };
      }
    },
  1. 在ios中下拉文案是英文这个问题,需要让ios在webview中设置一个属性(不太懂,可以直接把这个链接给ios开发看)
    参考来源:https://www.jianshu.com/p/9ed94a238e28
需要在info.plist 里面填加一个key表示app 使用系统的语言,
key为Localized resources can be mixed 设置为YES 就可以了

在这里插入图片描述
3. ios拍照上传会刷新整个页面问题:
先让ios排查webview中是否有调用触发刷新的方法

这个问题我是让ios排查的,因为很明显是触发了整个webview的刷新,
后面发现是他代码里写了进了某个生命周期,触发了整个页面的刷新,
历史遗留问题,是之前的开发写的,至于为什么,无从得知
在解决`van-uploader`打开 APP 相机的权限问题时,需要从多个方面进行考虑。 在 Web 环境下,使用`van-uploader`打开相机涉及到浏览器的媒体设备权限。当用户第一次尝试打开相机时,浏览器会弹出权限请求框,询问用户是否允许使用相机。如果用户拒绝,之后再次尝试打开相机时,浏览器可能不会再次弹出请求框。 在 APP 环境下,情况会更加复杂。APP 可能需要在原生层面进行权限配置。如果 APP 没有配置相机权限,即使`van-uploader`尝试打开相机,也会因为权限不足而失败。 对于 Web 环境,可以通过监听`getUserMedia`的错误来处理权限问题。示例代码如下: ```javascript navigator.mediaDevices.getUserMedia({ video: true }) .then(stream => { // 成功获取相机权限 console.log('成功获取相机权限', stream); }) .catch(error => { if (error.name === 'NotAllowedError') { // 用户拒绝了相机权限 console.error('用户拒绝了相机权限'); // 可以在这里提示用户去设置中开启权限 } else { console.error('获取相机权限时出现其他错误', error); } }); ``` 在 APP 环境下,如果是使用混合开发(如 Cordova、Ionic 等),可以使用相应的插件来处理权限问题。以 Cordova 为例,可以使用`cordova-plugin-camera`插件,它可以在 APP 层面请求相机权限。示例代码如下: ```javascript function takePicture() { navigator.camera.getPicture(onSuccess, onFail, { quality: 50, destinationType: Camera.DestinationType.FILE_URI, sourceType: Camera.PictureSourceType.CAMERA }); function onSuccess(imageURI) { // 成功拍摄照片 console.log('成功拍摄照片', imageURI); } function onFail(message) { if (message === 'Camera permission denied') { // 用户拒绝了相机权限 console.error('用户拒绝了相机权限'); // 可以在这里提示用户去设置中开启权限 } else { console.error('拍摄照片时出现其他错误', message); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值