百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

小程序开发中要避的坑

bigegpt 2024-08-09 11:16 2 浏览

小程序以免安装用完即走的特性自发布初就很火,即使是现在也是热度不减。小程序虽然是一个 HTML5,但是通过限制开发者的写法,提供一套自定义的组件以及写法,并且将一部分耗费性能的组件使用客户端渲染来极大的提高网页的性能。

小程序虽跟网页差距不大,但碰到坑的情况也是在所难免的,下面就我这段时间碰到的一些比较经典的问题来说一下我的解决方法。

遇到的问题

1

数据传输长度超过最大长度

一个新闻流的项目中,用户可以无限下拉加载数据,内部会使用一个数组将列表的数据存储起来。当我使用 tinajs 重构完项目后准备试试的时候发现,当我加载数据超过一定数量限制(大概200条数据)之后,控制台就会报“输出传输长度超过最大长度”的错误。

2

滚动问题

我们的小程序有一个下拉刷新的功能,小程序自己官方是有封装 onPullDownRefresh 接口来帮助我们完成这个事。不过因为我们的下拉刷新是有自定义样式的,所以就没办法使用官方的接口了。

最开始我是使用了 <scroll-view> 组件来做滚动,同时使用 scrolltoupper 来触发下拉的事件。内部则是使用了 translate 操作来展开下拉卡片。一顿操作之后觉得甚是完美,但是之后突然发现官方提示:

因为这几个组件都是使用 Native 实现的,只能是固定在屏幕上的存在,所以没办法在 scroll-view 中使用。同时使用了这个组件之后,外部的其它组件想要修改 scrllTop 的话会变得很麻烦,都需要自维护一套事件,增加了业务的复杂度。

3

Canvas画布问题

还有一个就是 Canvas 画布的问题。这个 Canvas 画布最大的问题在于小程序内部是使用客户端组件实现的,但是在开发者工具中由于是网页预览所以这里的是 HTML 中的 <canvas>。虽然微信将 HTML 原生的 canvas 大部分接口都实现了,但是我要说很多不一样,所以这就导致了开发者工具上看到的效果和客户端实际看到的效果有可能会完全不一样,给我们开发过程带来了无尽的阻挠。

解决方法

1

经过我和 tinajs 作者的逐一分析,发现可能是自定义组件的锅。因为我的列表元素有不同的样式,所以我使用了自定义组件去定义了不同的样式类型组件,部分组件又有公共的部分所以又要抽离出来变成组件,也就是说实际上我的列表是由一个多层嵌套的自定义组件循环渲染而成的。我们猜测最后小程序渲染的时候,每一个自定义组件传入的数据都会做一次拷贝,这样就导致了我本来 150K 的数据,瞬间就超过了它们的限制。

最后解决的办法也非常简单,由于我其实大多数都是纯渲染的组件,所以组件内部的自定义组件我都是用 <template> 模板去渲染,这种情况下不会触发数据的拷贝试了下就没有问题了。当然除了我说的减少数据体积以及用自定义模板代替自定义组件减少数据拷贝层级之外,我们还可以对数据进行分页操作来达到减少一次数据渲染的体积。

2

最终我退回成普通的 view 监听 touchstart, touchmove 和 touchend 事件,根据移动的距离来判断下拉百分比来实现这个功能。最终的实现可以说是异常艰辛的。不过这个实现完了之后,又出现了一个问题。在 iOS 中会存在阻尼效果,也就是下拉的时候滚动条会有一个回弹的特效,导致你虽然下拉了但是 touch 事件并没办法有效的执行。目前这个问题还没有比较好的解决办法,这里也有用户提出了需要提供禁止页面阻尼效果的参数,不过目前还没有官方回应。

3

由于是客户端渲染的画布,所以小程序的画布有以下几个比较明显的特点:

  • 小程序的画布是无限大的,使用 CSS 的宽高设置只是影响它的显示区域,并不会影像绘制。也就是说你发现元素绘制超出画布返回之后,只要设置画布的CSS 宽高即可让超出区域显示出来。如果是 HTML 中的画布的话应该是没有这个效果的。这样就导致了我们没办法同时设置绘制区域和画布大小这两个概念。
  • 小程序的画布因为是客户端渲染的,所以它永远是置顶的,z-index 属性是无效的。这个理解起来也非常简单,因为网页是使用客户端 WebView 组件加载的,画布又是另外一个客户端组件,两个客户端组件叠加只能是以层级的关系叠加,没办法做成嵌入式的。
  • 小程序的 ctx.draw() 方法是异步的,而且默认是清屏重绘的。这个和原生的画布是有区别的,之前我没有注意清屏重绘的问题导致调试了很久。
  • 小程序的 ctx.drawImage() 方法只能获取本地资源的图片。当你想要使用远程资源的时候必须先使用 wx.getImageInfo() 方法下载下来获取到路径之后才能使用 ctx.drawImage() 进行绘制。

另外还有一个问题在于,小程序的画布必须可视才能绘制成功,也就是说如果你给这个画布设置 display:none 然后等它绘制成功之后再显示出来是不可以的。目前我的解决办法是在页面用户不可视区域内先绘制然后再获取图片内容。

来源网络,侵权联系删除

相关推荐

10w qps缓存数据库——Redis(redis缓存调优)

一、Redis数据库介绍:Redis:非关系型缓存数据库nosql:非关系型数据库没有表,没有表与表之间的关系,更不存在外键存储数据的形式为key:values的形式c语言写的服务(监听端口),用来存...

Redis系列专题4--Redis配置参数详解

本文基于windowsX64,3.2.100版本讲解,不同版本默认配置参数不同在Redis中,Redis的根目录中有一个配置文件(redis.conf,windows下为redis.windows....

开源一夏 | 23 张图,4500 字从入门到精通解释 Redis

redis是目前出场率最高的NoSQL数据库,同时也是一个开源的数据结构存储系统,在缓存、数据库、消息处理等场景使用的非常多,本文瑞哥就带着大家用一篇文章入门这个强大的开源数据库——Redis。...

redis的简单与集群搭建(redis建立集群)

Redis是什么?是开源免费用c语言编写的单线程高性能的(key-value形式)内存数据库,基于内存运行并支持持久化的nosql数据库作用主要用来做缓存,单不仅仅是做缓存,比如:redis的计数器生...

推荐几个好用Redis图形化客户端工具

RedisPlushttps://gitee.com/MaxBill/RedisPlusRedisPlus是为Redis可视化管理开发的一款开源免费的桌面客户端软件,支持Windows、Linux...

关于Redis在windows上运行及fork函数问题

Redis在将数据库进行持久化操作时,需要fork一个进程,但是windows并不支持fork,导致在持久化操作期间,Redis必须阻塞所有的客户端直至持久化操作完成。微软的一些工程师花费时间在解决在...

你必须懂的Redis十大应用场景(redis常见应用场景)

Redis作为一款高性能的键值存储数据库,在互联网业务中有着广泛的应用。今天,我们就来详细盘点一下Redis的十大常用业务场景,并附上Golang的示例代码和简图,帮助大家更好地理解和应用Redis。...

极简Redis配置(redis的配置)

一、概述Redis的配置文件位于Redis安装目录下,文件名为redis.conf(Windows名为redis.windows.conf,linux下的是redis.conf)你可以通过C...

什么是redis,怎么启动及如何压测

从今天起咱们一起来学习一下关于“redis监控与调优”的内容。一、Redis介绍Redis是一种高级key-value数据库。它跟memcached类似,不过数据可以持久化,而且支持的数据类型很丰富。...

一款全新Redis UI可视化管理工具,支持WebUI和桌面——P3X Redis UI

介绍P3XRedisUI这是一个非常实用的RedisGUI,提供响应式WebUI访问或作为桌面应用程序使用,桌面端是跨平台的,而且完美支持中文界面。Githubhttps://github....

windows系统的服务器快速部署java项目环境地址

1、mysql:https://dev.mysql.com/downloads/mysql/(msi安装包)2、redis:https://github.com/tporadowski/redis/r...

window11 下 redis 下载与安装(windows安装redis客户端)

#热爱编程是一种怎样的体验#window11下redis下载与安装1)各个版本redis下载(windows)https://github.com/MicrosoftArchive/r...

一款轻量级的Redis客户端工具,贼好用!

使用命令行来操作Redis是一件非常麻烦的事情,我们一般会选用客户端工具来操作Redis。今天给大家分享一款好用的Redis客户端工具TinyRDM,它的界面清新又优雅,希望对大家有所帮助!简介Ti...

一个.NET开发且功能强大的Windows远程控制系统

我们致力于探索、分享和推荐最新的实用技术栈、开源项目、框架和实用工具。每天都有新鲜的开源资讯等待你的发现!项目介绍SiMayRemoteMonitorOS是一个基于Windows的远程控制系统,完...

Redis客户端工具详解(4款主流工具)

大家好,我是mikechen。Redis是大型架构的基石,也是大厂最爱考察内容,今天就给大家重点详解4款Redis工具@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集...