我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么让你的小程序健步如飞

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么让你的小程序健步如飞

这篇文章给大家分享的是有关怎么让你的小程序健步如飞的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

通过这种技术,可以缩短用户的等待时间,极大地提升用户的使用体验。由于那篇文章并未给出实现方式,只是讲解了技术原理,因此本文就来为大家讲下技术实现方式。

框架优缺点

优点:

  • 预加载下一个页面的数据,提高了页面的加载速度,轻量级的协议(200~300ms左右就能接收到数据)能轻松让小程序页面打开后数据瞬间加载,几乎不出现空页面。

  • 让同种业务的代码保持在一个类中,不会破坏项目结构。

  • 代码量非常少,对原本业务影响非常少。

  • 实现预加载后想删掉预加载?只需在实现的类中删除一个字符串即可。

缺点:

  • 需要你按情况替换setData为$setData

  • 需要开发者非常清楚各情况下的上下文是什么。

  • 如果你的协议非常耗时,达到400ms以上的,使用这种优化方式效果就不明显了。

  • 有网友发现,这个项目无法运行在使用了组件的小程序中,所以大家如果使用了组件的话,就不要直接用这个项目 了。不过还是推荐你吸收下这个项目的思想,毕竟工程师在工作中思想是很重要的。

这里就不为大家展示最终效果了,感兴趣的朋友可以自行尝试下。

如何集成

重要声明:我的小程序是遵循ES6标准写的,里面用了class extends及解构赋值等,如果看不懂的话,请学习下ES6!!如果你的项目是用的ES5,那就仔细阅读后续文章,体会预加载技术的核心思想,如果核心思想理解了,分分钟写一个出来,对吧 ~ ~

首先,你要有个基类CommonPage

小程序中的每一个Page类都继承该基类,这样的话才方便统一管理。

比如下面的IndexPage页面

// pages/index/index.jsimport CommonPage from "../CommonPage";class IndexPage extends CommonPage {    constructor(...args) {        super(...args);        this.data = {            testStr: 'this is the firstPage'        }    }    onLoad(options) {    }}Page(new IndexPage());

IndexPage是第一个页面,不需要预加载,SecondPage是第二个页面,我们来模拟下SecondPage的预加载方式。

接下来看到的this.$route() this.$put() this.$take() this.$resolve() this.$reject()等带$符号的都是基类中实现的方法。

给IndexPage页面添加跳转按钮。

<!--index.wxml--><view class="container">    <view bindtap="toSecondPage" hover-class="press-style" class="normal-style" hover-stay-time="100"> 闪电加载第二个页面</view>    <view>300毫秒 闪电加载方式</view></view>

注意:这里添加的class="normal-style" hover-stay-time="100"是非常重要的,如果不添加点击态,会很影响体验。

给IndexPage页面添加预加载专用跳转方式。

 toSecondPage = function () {        // this.$route是预加载的页面跳转方式,以wx.navigateTo方式跳转。这个方法是在CommonPage中实现的。        this.$route({path: '../second/second', query: {count: 10, title: '这是第二个页面'}, clazzName: 'SecondPage'});// 这是小程序原生的普通加载方式        // wx.navigateTo({        //     url: '../second/second?count=10&title=这是第二个页面'        // })    }

this.$route({path, query, clazzName});这个方法的参数含义是:

  • path:页面路径,支持绝对路径和相对路径。

  • query:需要传递的参数。这是一个object类型的。

  • clazzName:需要跳转的页面的类名。这个介绍SecondPage时再说。

其实你可能会问,既然有path了,为什么还要clazzName?这个问题会在介绍技术原理时详细说,那是下一篇的事儿了。

到这里,如果你也是用ES6的规范来实现类的,可以看到,在IndexPage中,你只需将跳转方式修改为this.$route({path, query, clazzName});即可。

给SecondPage页面添加预加载专用的初始化方法。

// pages/second/second.jsimport CommonPage from "../CommonPage";class SecondPage extends CommonPage {    constructor(...args) {    //super(...args)一定要写,他会将clazzName与下面的data进行合并。        super(...args);        //这个$init(obj)中注入的obj就是页面初始时的data        super.$init({            arr: []        });    }    $onNavigator(query) {    //这里的query是从this.$route中传递来的query        console.log('闪电️加载时接收到的参数', query);        this.$put('second-data', this.initData.bind(this), query);    };    initData = function (query, resolve, reject) {    //这里的query是在this.$put()中传递过来的    //resolve在协议成功时回调    //reject在协议失败时回调    //模拟网络请求        setTimeout(() => {            if (typeof query.count === "string") {                query.count = parseInt(query.count);            }            this.data.arr.splice(0, this.data.arr.length);            for (let i = 0; i < query.count; i++) {                this.data.arr.push({id: i, name: `第${i}个`, age: parseInt(Math.random() * 20 + i)})            }            this.$setData(this.data);            this.$resolve(this.data);//或者 resolve(this.data);只有调用了resolve或者reject方法,才能在this.$take()的then()方法中获取到值。        }, 300);    };    onLoad(options) {        const lightningData = this.$take('second-data');        if (lightningData) {            lightningData.then((data) => {            //成功回调,resolve(data)调用时触发 data就是resolve传递的参数                this.$setData(data);            },(data, error)=>{            //失败回调,reject(data, error)调用时触发,data和error是reject传递的参数。            });            return;        }        this.initData(options);    }}//这里注入的clazzName: 'SecondPage',与this.$route({path, query, clazzName});中的clazzName名称与其一致即可Page(new SecondPage({clazzName: 'SecondPage'}));

大概是这么几步:

  • 这个类需要在new时,将clazzName注入,this.$route({path, query, clazzName});中的clazzName名称与其一致即可。

  • 需要在SecondPage中注入新的生命周期函数,也就是预加载方法。在执行this.$route时,你在this.$route中传递的clazzName是什么,这个框架就会自动去找匹配一致的类,调用该类的$onNavigator方法。

  • 在$onNavigator中调用this.$put(key,fun,query)参数分别是键、异步请求方法、异步请求方法的参数。

  • 在异步请求方法将this.setData替换为this.$setData(),使用this.$resolve(data)或者this.$reject(data,error)来回调成功或失败。

  • 在onLoad中使用this.$take(key).then(success,fail)来获取异步结果,分别对应了resolve和reject回调。如果你没有使用预加载,或者预加载失败,那么this.$take(key)方法返回空,由此可以判断是否使用了预加载进入页面!

这么做的话,实现了在跳转前先把下一个页面的协议发出去,而且还让同种业务的代码保持在一个类中,不会破坏项目结构!

在实现了预加载后,如果不想用预加载了,只需要删掉new SecondPage()时注入的clazzName即可!

感谢各位的阅读!关于“怎么让你的小程序健步如飞”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么让你的小程序健步如飞

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么让你的小程序健步如飞

这篇文章给大家分享的是有关怎么让你的小程序健步如飞的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。通过这种技术,可以缩短用户的等待时间,极大地提升用户的使用体验。由于那篇文章并未给出实现方式,只是讲解了技术原理,因
2023-06-14

如何让客户更加信任你的小程序

这篇文章主要讲解了“如何让客户更加信任你的小程序”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何让客户更加信任你的小程序”吧!1.游客变粉丝为了避免用户被骚扰,小程序的用户通知和唤醒功能被
2023-06-27

操作系统容器编排:如何选择合适的平台,让你的应用程序飞起来

操作系统容器编排平台是管理和协调容器化应用程序的关键技术,本文将从不同维度分析主流平台,帮助您选择最适合您需求的平台,让您的应用程序飞起来。
操作系统容器编排:如何选择合适的平台,让你的应用程序飞起来
2024-02-12

Java线程同步与互斥:多线程编程的必备技能,掌握它,让你的程序如丝般顺滑

多线程编程是一项复杂的技能,需要对线程同步和互斥有深入的理解。本文将介绍Java中的线程同步和互斥,并提供示例代码,帮助您掌握多线程编程的必备技能,让您的程序运行顺畅如丝。
Java线程同步与互斥:多线程编程的必备技能,掌握它,让你的程序如丝般顺滑
2024-02-09

小程序中怎么优雅的捕捉异步方法的异常

小编给大家分享一下小程序中怎么优雅的捕捉异步方法的异常,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!传统方法在ES7之后,我们往往使用 async await 语
2023-06-22

微信小程序后端Java接口开发的步骤是怎么样的

这篇文章给大家介绍微信小程序后端Java接口开发的步骤是怎么样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。微信小程序使用wx.request(OBJECT)来调用后端接口。首先 我们来一个简单案例 —— hello
2023-06-25

怎么在小程序中如何实现一个可截断的瀑布流组件

这期内容当中小编将会给大家带来有关怎么在小程序中如何实现一个可截断的瀑布流组件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。瀑布流是一种常见的布局方式,实现的方式有许多,比如直接分两列,然后控制在左右两列
2023-06-28

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录