微信小程序|小程序如何判断openDocument被关闭

前言:

在微信小程序中,预览文件用的都是wx.openDocument()方法。现在有个需求,需要在文件关闭后调用一个方法。那么,如何知道文件已经被关闭了呢?

此文将对此问题提供思路和方案。

一、实现思路

因为小程序没有监听openDocument关闭事件的方法。

所以,我的思路是:

  1. 声明一个变量flag的默认值为false,用于记录文件是否已经打开过;
  2. 打开文件的时候设置缓存变量flagtrue
  3. 页面onShow的时候,获取缓存flag的值并开始判断;
  4. flag有值并且为true的时候,处理自己的逻辑,同时将flag恢复默认值false

二、实现方案

按照思路步骤依次如下图所示:

下面附上相关的所有代码:

js 复制代码
Page({
  data: {
    flag: false,
  },
  
  onLoad: function (options) {
    this.wxDownLoad(options); // 因为我的需求是页面onLoad的时候就打开文件
  },
  
  wxDownLoad(options) {
    let that = this;
    wx.showLoading({
      title: '正在打开...',
    });
    wx.downloadFile({
      url: options.url,
      filePath: wx.env.USER_DATA_PATH + "/" + decodeURIComponent(options.name), // 设置自定义标题
      success: (res) => {
        if (res.statusCode === 200) {
          const filePath = res.filePath;
          wx.openDocument({
            showMenu: true,
            filePath: filePath,
            success: function (res) {
              that.setData({ flag: true })
              wx.hideLoading();
            },
          })
        }
      }
    })
  },
  
  onShow: function () {
    if (this.data.flag) {
      this.setData({ flag: false })
      wx.navigateBack();
    }
  },
})
·

三、需求拓展

备注:

我这边的具体需求是这样的:
微信小程序webview内嵌的H5页面中,点击H5的文件能在小程序中打开。

为了实现这个需求,在H5与微信小程序通信时,设计点击H5中的文件跳转到小程序的一个空白页,然后在空白页onLoad的时候,进行打开文件的操作。

但是这样的话,在关闭文件时会显示空白页,影响用户体验,所以需要在关闭文件的时候,自动将空白页关闭,直接显示内嵌的H5页面。

也就是只要判断文件已经被关闭,然后调用wx.navigateBack()即可实现。

另:此文也可作为上一篇文章---------微信小程序中webView的H5页面与小程序双向通信,调用微信小程序预览文件功能 中预览文件功能的细节补充。

以上,希望对大家有帮助!

相关推荐
凌涘14 小时前
依托 BEM 规范深度剖析 WeUI 微信按钮组件开发与实现
前端·微信
px不是xp17 小时前
【灶台导航】优化纠错实录
javascript·微信小程序
爱勇宝20 小时前
我做了一个亲子成长小程序:想把“催孩子”变成“看见孩子”
微信小程序·产品·全栈
m0_696212681 天前
如何用微信 API 实现多群消息同步和定时群发
微信
罗光记1 天前
Solon Server 启动模式深度解析:从 0.3MB 内核到 10+ Server 插件
其他·百度·微信·微信公众平台·新浪微博
克里斯蒂亚诺更新1 天前
微信小程序体验版可以获取当前位置但是正式版不可以-办法解决
微信小程序·小程序
巴巴博一1 天前
uni-app / 微信小程序中 open-type=“share“ 按钮样式异常,和普通 view 无法齐平的解决方案
微信小程序·uni-app·notepad++
资深前端之路1 天前
微信小程序节点最大限制为5000个
微信小程序·小程序
wuxia21181 天前
微信小程序单击元素切换元素的显示和隐藏
javascript·微信小程序·setdata
silvia_Anne2 天前
微信小程序之渲染商品列表
微信小程序·小程序