关于wx.downloadFile预览一直请求的解决方案以及踩坑(真机调试和开发没问题)

1.配置合法域名:网络 | 微信开放文档

2.关于下载的文档打不开(或者已损坏):检查url是否有效。

3.关于真机和开发时正常,预览时一直加载问题:查看请求的地址和配置的域名,它们协议是否一直(自己踩坑:配置的https,请求的是http),可以尝试关闭合法域名校验进行调试。

4.对于测试,需要清除小程序缓存:(ios删除小程序,重新登录可以清除缓存。)

5.关于预览的文件需要分享:wx.openDocument里设置showMenu: true

6.关于自定义文件名:设置wx.downloadFile的filePath

filePath:wx.env.USER_DATA_PATH+'/'+文件.后缀名
//例如:12345.doc
//需要注意:当设置了filePath后返回的是字段是filePath(没设置的时候为tempFilePath)

7.付完整代码

previewFile(ev) {
    const flieArr = ev.currentTarget.dataset.filename.split('.')
    const fileType = flieArr[flieArr.length - 1]
    wx.showLoading({
      title: '加载中...',
      mask: true
    }),
    wx.downloadFile({
      url: ev.currentTarget.dataset.url,
      filePath:wx.env.USER_DATA_PATH+'/'+ev.currentTarget.dataset.filename,
      success: function (res) {
        const filePath = res.filePath
        wx.openDocument({
          filePath,
          fileType,
          showMenu: true,
          complete:function(){
            wx.hideLoading()
          }
        })
      },
    })
  },

`wx.downloadFile` 是微信小程序提供的一个API,用于从网络下载文件。在使用这个方法时,涉及到用户权限的问题主要是关于网络请求和存储权限的管理。 1. **网络请求权限**:默认情况下,微信小程序开发工具中不需要用户授权即可进行网络请求,但在真机环境下,你需要在`app.json`中的`permission`配置中设置`scope.network`权限。在实际项目中,通常在用户首次打开应用时弹出权限提示,获取用户的同意。 ```json { "permissions": { "scope.network": { "desc": "你的应用需要访问网络", "needUserPermission": true } } } ``` 调用 `wx.downloadFile` 之前,需要先检查权限: ```javascript wx.getSetting({ success(res) { if (!res.networkType || res.networkType === 'none') { wx.authorize({ scope: 'scope.network', success() { // 用户已授权,可以进行下载操作 wx.downloadFile({ url: '你的下载地址', ... // 下载配置 }); }, fail() { // 用户拒绝授权,这里可以处理拒绝的情况 } }); } else { // 用户已授权,可以直接下载 wx.downloadFile({ url: '你的下载地址', ... // 下载配置 }); } } }) ``` 2. **文件存储权限**:如果下载的文件需要保存到本地,还需要用户授予文件系统权限。在`app.json`中设置`scope.fileSystem`权限,并在真机上同样需要用户授权。不过微信小程序一般不推荐直接保存用户数据到本地,而是建议使用云开发或微信提供的其他存储方式。 注意及时遵守平台的隐私政策和用户体验最佳实践。在实际操作中,确保向用户清晰地解释为何需要这些权限,以及如何使用它们。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值