小程序自定义导航栏后下拉刷新思考

背景

由于小程序原生的导航栏很难满足现有的需求,所以很多开发者会考虑通过"navigationStyle": "custom"自定义一个符合要求的导航栏,而这个自定义导航栏的操作往往是发生在全局配置的app.json中。也就是说每个页面都需要使用自定义的导航栏以便统一风格。
同时,项目中总有页面需要下拉刷新或上拉加载更多的需求,小程序在自定义导航栏之后,如需使用原有的enablePullDownRefresh就会遇到如下两个问题:

问题1:自定义导航栏后原有的下拉刷新动画位置显示不正确


然而对于这个bug,官方的回应是:

既然微信还没修复这个问题,那么我最先的想法是在自定义的导航栏底层自定义一个可以滑动的下拉刷新动画,同时利用微信提供的backgroundTextStyle隐藏系统自带的下拉刷新样式。这样即可以触发微信原有的下拉刷新方法,又能自定义动画。
但是,出现了第二个问题。

问题2:自定义导航栏后,开启系统下拉刷新会导致安卓端fixed的元素一起向下滑动。
也就是整个导航栏会跟着一起滑动下去(iOS端没有问题)。所以目前看来,如果你自定义可导航栏,那么系统原生的下拉刷新是没办法使用的。

正文

因为这两个硬性bug,导致目前的小程序开发者要么使用微信原生的导航栏+刷新,要么是把列表通过微信组件scroll-view包装一层,然后使用bindscrolltoupperbindscrolltolower处理刷新方法。
文档中有明确指出:


所以这种方式固然也不是什么好办法,只是当下的没有办法的办法。

此外,scroll-view本身,对于iOS和安卓两端的处理又有一些区别,比如iOS端在scrollTop下拉会有一个弹簧效果,即scrollTop可能出现负值。但是在安卓端就没有这样一个弹簧效果。所以才会有官方文档中的第4条若要使用下拉刷新,清使用页面的滚动

效果图

上面这个GIF是我尝试性的做了一个假的下拉刷新动画,置于scroll-view的顶部。触发和推出时都用createAnimation()处理,尽可能让其变得流畅一点。

使用

1 将组件导入您的项目,并引用

"usingComponents": {
    "top-refresh": "/components/top-refresh/top-refresh"
  }

2 wxml,绑定一个唯一id

<top-refresh id='tfresh'></top-refresh>

3 js,相应位置触发

const com = that.selectComponent('#tfresh')
// 控制是否正在刷新
if (com.data.toprefresh) {
  return
}
// 启动刷新动画
com.refreshstart()
// 停止刷新动画
com.refreshend()

当然,你可以把它用在scrollview底部。
如果你有安装微信开发者工具,可以直接查看这个代码块

注意:
这个组件并没有对scrollview触发下拉的方式起作用,只是做了一个动画告诉用户现在页面正在刷新。你也可以使用其他的方式(比如b站在下拉的时候会调用设备震动的API,告诉用户下拉的时候触发了刷新操作)。

结尾

我觉得小程序是一个高度封装的开发工具。所以应该用最简单的方式实现想要的效果。这才符合小程序设计的初衷。

希望小程序官方早点修复,让我们摆脱scroll-view。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 今天中午陪孩子写日记,感觉比头几天强了一点点。
    加油_e70a阅读 361评论 0 0
  • 2013年 那时 我们从未见过 可当我第一眼看到你的时候 却觉得已经等了很久 每每故意借A4 只为和你说一句话……...
    Bob彭阅读 374评论 0 0
  • 不知道从哪里得知,写给自己的文字,当回忆时,总是一片混乱。 那就写给任何人吧。 像沙粒在沙漏中慢...
    Carden_阅读 276评论 0 0
  • 伴着三月的桃花 带着满心的欢喜 走进三一班 走进古灵精怪的你们 时间加速度流走 情义在心中累积 从未说出你们在我心...
    仙人掌也孤独阅读 284评论 1 3