最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 【小程序云函数】数据周期性更新&数据预拉取踩坑

    正文概述 掘金(Jervis_cen)   2021-01-26   1205

    前言

    为增强小程序在弱网下的使用体验,开始对小程序数据周期性更新、数据预拉取这两个官方提供的功能的做一下可用性体验测试。

    功能开通

    主要开启入口,登录小程序MP管理台 -> 开发 -> 开发管理 -> 开发设置 (然后拉到最后)。

    选择开启后会弹出管理员扫码弹窗。扫码之后会让你选择使用业务域名还是云函数来调用此功能。(下面我们以开通周期性更新作为流程案例)

    【小程序云函数】数据周期性更新&数据预拉取踩坑

    业务域名

    2020年11月增加了新规定,个人用户在开通【数据周期性更新/数据预拉取】功能只能选择云函数(在此之前还有一个https域名的选项),而企业用户可选择业务域名和云函数。 业务域名:需要经过icp认证与企业有业务关联的域名。

    云函数

    因为还处于摸索阶段,我们就不劳烦后端和运维大哥。这两个功能都统一走云函数这个模块。 在选择使用云函数开发周期性更新后,会有下面这个弹窗提示你选择环境ID和云函数名,用以部署周期性更新。 【小程序云函数】数据周期性更新&数据预拉取踩坑

    正常来说选择了云函数并提交后就算是部署了周期性更新了,但是在此之前,你得开通云开发并且创建云函数。

    开通云开发

    开通云开发两种方式

    1.重新开启一个小程序项目

    在MP控制台—> 开发 —> 云开发 里开通功能,然后本地新建项目 【小程序云函数】数据周期性更新&数据预拉取踩坑

    勾选【小程序·云开发】就能快速构建带有云开发模板的项目。

    2.在已有的项目上添加云开发。

    首先你要在已有项目中的project.config.json文件中添加字段

    "cloudfunctionRoot": "cloudfunction/",
    

    增加这个路径之后,在小程序编辑器的目录中右键cloudfunction文件夹(如果编辑器没有新建就手动在根目录建一个同名文件夹)选择新建Node.js 云函数。 然后你就有了一个这样的文件模板。如果要运行本地测试还需要在这个目录下运行npm i (这里推荐yarn)

    【小程序云函数】数据周期性更新&数据预拉取踩坑

    新建&部署

    新建testWeakNet云函数之后

    // testWeakNet.js
    const cloud = require('wx-server-sdk')
    
    cloud.init({
      env: cloud.DYNAMIC_CURRENT_ENV
    })
    console.log('当前环境', cloud.DYNAMIC_CURRENT_ENV)
    // 云函数入口函数
    exports.main = async (event, context) => {
      console.log(event, context)
      const wxContext = cloud.getWXContext()
      return {
        openid: wxContext.OPENID,
        appid: wxContext.APPID,
        unionid: wxContext.UNIONID,
      }
    }
    

    写好代码之后右键选择要部署的云函数,选择【创建并部署】之后点击小程序开发工具左上角的云开发然后在云开发tab新建同名云函数。

    【小程序云函数】数据周期性更新&数据预拉取踩坑

    最后配置好云开发的状态: 【小程序云函数】数据周期性更新&数据预拉取踩坑

    调用

    周期性更新与预拉取都是共用wx.getBackgroundFetchData这个api,唯一区别是fetchType。预拉取使用pre,周期性更新使用periodic。而wx.setBackgroundFetchToken看官方文档的解释:

    可以看做是调用这个功能的初始化类似于cloud.init()

    // app.js
    cloudFunction() {
        // 云函数初始化
        if (!wx.cloud) {
            console.error('请使用 2.2.3 或以上的基础库以使用云能力');
        } else {
            wx.cloud.init({
                env: 'xxxxx-xxxxx', // 想要请求切换哪个云环境,就用哪个的
                traceUser: true,
            });
        }
        
        wx.setBackgroundFetchToken({
            token: 'weakNet'
        });
        // 弱网数据拉取 256kb 限制 fetchType ? periodic 周期数据更新 / pre 预拉取
        wx.getBackgroundFetchData({
            fetchType: 'pre',
            success(res) {
                const fd = JSON.parse(res.fetchedData);
                console.log('pre_fetch success', fd);
            },
            fail(e) {
                console.log('pre_fetch fail', e);
            },
            complete(e) {
                console.log('pre_fetch complete', e);
            }
        });
    },
    

    调试

    数据周期性更新:

    微信开发者工具 -> 工具 -> 拉取周期性缓存数据 选择之后控制台会出现缓存的提示 【小程序云函数】数据周期性更新&数据预拉取踩坑

    数据预拉取: 开发工具右边的详情中打开本地设置,勾选【启用数据预拉取】 【小程序云函数】数据周期性更新&数据预拉取踩坑 设置成功后在控制台可以看到拉取的云函数回调 【小程序云函数】数据周期性更新&数据预拉取踩坑

    注意事项

    不管是数据预拉取还是数据周期性更新,有以下几点注意事项

    1. 在获取的缓存数据fetchData 的格式都是 JSON 字符串
    2. 缓存数据不能大于256KB
    3. 云函数内不能调用云函数
    4. 云函数的部署和本地代码要及时清除缓存
    

    关于第三点【云函数内不能调云函数】 原因: 【小程序云函数】数据周期性更新&数据预拉取踩坑 我的预拉取数据云函数testWeakNet 中调取了同环境下的request云函数,但是返回的res没有把request的结果转出来,而是直接吧res赋值的函数字面量字符串化作为返回发到了客户端 【小程序云函数】数据周期性更新&数据预拉取踩坑

    常见报错类型:

    1. 错误码:-10007。没有在MP开启功能 & 没有设置token
    2. 错误码:-501003。当前周期性数据: {"errcode":-501003,"errmsg":"Request exceeded the limit"}。这有几种可能。当前云环境处于限制状态处于隔离期,或者请求超过当日限制数。

    【小程序云函数】数据周期性更新&数据预拉取踩坑

    参考文档

    1.微信小程序|周期性更新:https://developers.weixin.qq.com/miniprogram/dev/framework/ability/background-fetch.html

    2.微信小程序|数据预拉取:https://developers.weixin.qq.com/miniprogram/dev/framework/ability/pre-fetch.html

    3.微信小程序|我的第一个云函数:https://developers.weixin.qq.com/miniprogram/dev/wxcloud/guide/functions/getting-started.html


    起源地下载网 » 【小程序云函数】数据周期性更新&数据预拉取踩坑

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元