pullRefreshLoop

setCustomRefreshHeaderInfo refreshHeaderLoadDone

论坛示例

为帮助用户更好更快的使用模块,论坛维护了一个,示例中包含示例代码、知识点讲解、注意事项等,供您参考。

概述

本模块可实现的下拉刷新示例图如下:

随着用户对 App 使用体验的要求不断提升,传统的下拉刷新动画和模式已经无法满足用户挑剔的视觉体验。为满足广大开发者对下拉刷新功能的需求,我们推出了最新最炫的下拉刷新模块助您提升 App 逼格。

从用户体验考虑,下拉刷新的实现不能简单粗暴的用一张 GIF 图片来完成,我们需要遵照原生动画理念,使用关键帧(即多张具有微小差别的图片)来完成完整的动画过程。

下拉刷新简介

下拉刷新是指在一个可上下拖动查看内容的支持弹动功能的窗体(frame、window)中,用户通过下拉触发刷新数据事件从而加载数据刷新页面的过程。

此过程可拆分为四个组成部分:

  • 一,下拉过程
  • 三,加载状态
  • 四,数据加载完成后刷新页面并停止加载状态(恢复常态)

pullRefreshLoop 模块对引擎新推出的下拉刷新接口进行了一层封装,App 可以通过此模块来实现带炫酷动画效果的下拉刷新功能。使用此模块,在用户下拉时本模块会随用户下拉高度而显示出下拉出的提示图标;当下拉高度到一定阈值后出发加载事件,与此同时,下拉提示图标会改变为一直旋转状态,将下拉刷新事件回发给前端。下拉图标及背景图是通过 api.setCustomRefreshHeaderInfo 接口传给模块的。前端得到下拉刷新事件后开始加载数据;数据加载完毕,调用接口 api.refreshHeaderLoadDone 以停止加载状态;

模块使用攻略

对于 APICloud 平台上的普通模块,在相应接口调用前需要先 require 该模块,但由于本模块是基于引擎下拉刷新功能扩展的模块,所以本模块使用方法比较特殊。可以不必 require 模块,改为在 config.xml 文件内配置模块。

文件配置示例如下:

config.xml 配置后,则本模块为全局对象,可以在任意可弹动的窗体(frame、window)中调用 api.setCustomRefreshHeaderInfo 接口设置该下拉刷新样式,以及开始、停止刷新加载状态(api.refreshHeaderLoading、api.refreshHeaderLoadDone)。

若想在不同的 window 或 frame 使用不同的下拉刷新模块,开发者可以在 window 或 frame 打开时传入参数 customRefreshHeader:’下拉刷新模的块名’,以指定该窗体的下拉刷新模块。如:

  1. api.openFrame({
  2. name: 'pullRefreshLoop-con',
  3. url: './pullRefreshLoop-con.html',
  4. customRefreshHeader: '下拉刷新模块名',
  5. bounces: true,
  6. rect: {
  7. x: offset.l,
  8. y: offset.t + offset.h,
  9. w: offset.w,
  10. }
  11. });
  12. }

注意:本模块无接口,模块的所有功能都通过 api 对象的相应接口实现

功能接口

setCustomRefreshHeaderInfo

配置下拉刷新样式

api.setCustomRefreshHeaderInfo({params}, callback())

  • 描述:启用下拉刷新及其样式的配置
  • 内部字段:

callback()

  1. api.setCustomRefreshHeaderInfo({
  2. bgColor: '#C0C0C0',
  3. image: {
  4. icon: 'widget://image/refresh/miao.png',
  5. borderColor: '#f00'
  6. },
  7. }, function() {
  8. alert('下拉刷新事件触发了,摇动手机关闭下拉状态');
  9. api.addEventListener({
  10. name: 'shake'
  11. }, function(ret, err) {
  12. api.refreshHeaderLoadDone()
  13. });

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

refreshHeaderLoading

手动开始下拉刷新的加载状态,下拉刷新状态亦可通过用户下拉到阈值自动触发

api.refreshHeaderLoading()

可用性

iOS系统,Android系统

可提供的1.0.0及更高版本

refreshHeaderLoadDone

手动停止下拉刷新的加载状态

api.refreshHeaderLoadDone()

  1. api.refreshHeaderLoadDone();

可用性

iOS系统,Android系统