react native loading动画_react-native-easy-app 详解与使用之(三) View,Text,Image

react-native-easy-app 是一款为React Native App快速开发提供基础服务的纯JS库(支持 IOS & Android),特别是在从0到1的项目搭建初期,至少可以为开发者减少30%的工作量。

react-native-easy-app 主要做了这些工作:1. 对AsyncStorage进行封装,开发者只需几行代码即可实现一个持久化数据管理器。2. 对fetch进行封装,使得开发者只需关注当前App的前后台交互逻辑和协议,定义好参数设置及解析逻辑即可。3. 重新封装了RN的View、Text、Image、FlatList 使用得这些控件在适当的时候支持事件或支持icon与文本,能有效减少布局中的嵌套逻辑。4. 通过设置一个屏幕参考尺寸,重置XView、XText、XImage的尺寸,实现自动多屏适配。

可能有人觉得,不同的App有不同的风格UI也完全不一样,除非是特定需求的UI,基础功能的UI直接写就行了,还需要封装么?

一千个人心中,有一千个哈姆雷特,也许我的封装思路能给你带来不一样的启发也未可知呢?

简单UI(XView,XText,XImage)

1、事件支持
View,Text,Image作为使用频率最高的三个组件,并不支持我们最常使用的onPress事件,我们要使用onPress事件时,得使用TouchableXXX系列组件来包裹指定的点击区域。

X系列组件使用得这三个基本组件支持onPress事件,实现原理很简单,若传入的属性中包含onPress方法,则返回一个由Touchable系列组件(默认为:TouchableOpacity)包裹的组件,否则返回原组件。其它用法跟原生组件一致,所有原生属性都支持:

XWidget

v2-f6926a106ab40feb065f6bcfc38206e3_b.jpg
  • XImage也支持通过iconSize对内部图片设置独立的尺寸理了快速重复点击问题】
  • 若设置了资源资源的baseUrl,图片的icon由只需要设置图片【名称】即可
  • 当然icon支持多种类型:url、require('./name.jpg'),base64码等方式
  • RFImage也支持通过iconSize对内部图片设置独立的尺寸

2、XText支持图标设置
很多情况下UI的展示是一个文本一个图标的组合,所以我们的做法基本上都是通过一个View去包裹Image与Text,这样使用得UI布局结构变得相对复杂,这时候就可以使用XText了

<

v2-e0645f9d57beb88f404dfcb79187a5cd_b.jpg

或许,从止面的代码和展示出的UI看不出有什么方便之处,下面我举几个例子:

<

v2-16120e4572362b2e2351ad8d75fddfbc_b.jpg
  • 如果从UI很难看出上面的这些各种类型的UI元素竟然是同一个控件XText实现的,但事实却是如此。
  • 当然,这种包裹嵌套方式自然会引出另一个问题,当给这些UI设置属性时,属性是被传给外层的View还内层的Text呢?不用担心内层包装已经做了处理,将传入的属性和样式做了拆分,属于Text的属性和样式会传给Text,剩下的再传给外层的View

复杂UI(XFLatList)

1、下拉刷新与分页支持
下拉刷新,滚动到底部加载更多数据是很常见的应用场景,但原生的Flatlist并不支持,故对原生Flatlist进行了一下简单封装,并支持以下状态:

static 
  • 各状态文本描述可以自由订制

v2-e322dc66388fae0b32924ad071d4b288_b.jpg

v2-dd85328d8af236fcc92fc66db3f3dea2_b.jpg

v2-7616da00dbbc90c57bafcba474629c81_b.jpg

v2-b46dfee39575d35c3a19475f7f6586c6_b.jpg
  • XFLatlist的用法与原生Flatlist几乎一样,原生属性也都支持:
<
  • 怎样发发送请求与设置数据,保证列表的刷新、加载更多等功能正常的展示呢?主要掌握两个方法的使用即可:
  1. refreshPreLoad = (isPullDown) => {};
    在http请求发送【前】调用XFlatlist的 refreshPreLoad 方法并传入是否是下拉刷新
  2. refreshLoaded = (success, isPullDown, noMoreData, networkException) => {}
    在http请求发送返回【后】调用XFlatlist的 refreshLoaded 方法:
  • success =>请求成功与失败
  • isPullDown =>当前操作是下拉还是加载更多
  • noMoreData =>是否已经没有更多数据
  • networkException =>是否网络异常

我们看看示例分页列表的完整实现:

queryDataList 

发现是不是很简单?通过XFlatlist 20几行代码就能完整的实现一个支持下拉刷新,分页加载等各种状态功能的列表。

react-native-easy-app 详解与使用之(四)屏幕适配

想进一步了解,请移步至 npm 或github查看 react-native-easy-app,有源码及使用示例,待大家一探究竟,欢迎朋友们 Star!

如果有任何疑问,欢迎扫码加入RN技术QQ交流群

v2-e9eeb4e03d0cbdd5319e370080473153_b.jpg
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值