【小程序踩坑系列】小程序退出后扫码再进入,“外部”代码不会再次执行 ... - 新闻资讯 - 云南小程序开发|云南软件开发|云南网站建设-昆明葵宇信息科技有限公司

159-8711-8523

云南网建设/小程序开发/软件开发

知识

不管是网站,软件还是小程序,都要直接或间接能为您产生价值,我们在追求其视觉表现的同时,更侧重于功能的便捷,营销的便利,运营的高效,让网站成为营销工具,让软件能切实提升企业内部管理水平和效率。优秀的程序为后期升级提供便捷的支持!

您当前位置>首页 » 新闻资讯 » 小程序相关 >

【小程序踩坑系列】小程序退出后扫码再进入,“外部”代码不会再次执行 ...

发表时间:2021-3-31

发布人:葵宇科技

浏览次数:56

作者: 蒋欢

问题:

小程序退出后再次扫码进入,只会执行生命周期函数里的代码,“外部”代码不会再执行。

具体描述:

在我们的项目里,我们会将一部分本地变量不写在小程序 pageConfig 的 data 中,而直接在文件头进行声明。这样是为了减少 data 的大小,加快页面渲染速度。但这也无意中带来了新问题,我们看看下面的例子。

出错的index.js文件

    const localFlag = true; // “外部”代码,仅执行一次初始化,第二次扫码不会执行!

    const pageConfig = {
        data: {
            text: 'init data'
        },
        onLoad(this, p) {  
            console.error("localFlag默认为:"localFlag);

            // Do something you need...
            localFlag = false;
        }
    }

    Page(pageConfig);

按照以上代码运行,用户初次扫码时,localFlag的值为true。可是,当用户退出小程序,再次扫码进入时,localFlag没有再初始化,而为false了。如下图所示:

如何避免上述情况的出现呢?

其实也很简单,就是在文件头部只做本地变量声明,而不做定义。将定义部分放在生命周期函数(如:onload)内。具体代码如下:

正确的ndex.js文件

    const localFlag; // 只做变量声明而不定义

    const pageConfig = {
        data: {
            text: 'init data'
        },
        onLoad(this, p) {  
            localFlag = true;
            console.error("localFlag默认为:"localFlag);

            // Do something you need...
            localFlag = false;
        }
    }

    Page(pageConfig);

如此,每次进入页面 localFlag 都会被置为 true 了。

环境:

IOS 和 安卓 均可稳定复现。

原因:

这看起来属于小程序自身的模块设计方式导致的。推测即使退出小程序,之前打开的页面也没有做到真正卸载,而处在内存之中。下次再次进入同一个页面时,会被唤起。

解决方案:

只在头部代码进行本地变量声明,而不定义。将本地变量的定义放在生命周期函数中去。

风险:

属于小程序开发的经验积累相关。

相关案例查看更多