组件
hippy-react 的组件接近终端,语法上接近 React Native。
Image
图片组件,用于显示单张图片。
- 注意: 必须指定样式中的宽度和高度,否则无法工作。
- 注意: Android 端默认会带上灰底色用于图片占位,可以加上
backgroundColor: transparent
样式改为透明背景。
基本用法
直接加载远程图片:
<Image
style={{ width: 200, height: 200 }}
source={{ uri: 'http://xxx/qb_icon_new.png' }}
resizeMode={Image.resizeMode.cover}
/>;
或者使用本地图片加载能力:
import icon from './qb_icon_new.png';
<Image
style={{ width: 200, height: 200 }}
source={{ uri: icon }}
resizeMode={Image.resizeMode.cover}
/>
- 本地图片可通过加载时定义 Loader,或者 webpack 配置
url-loader
转换成 base64 加载。2.8.1
版本后支持终端本地图片能力,可通过配置 webpackfile-loader
加载。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
onLayout | 当元素挂载或者布局改变的时候调用,参数为: { nativeEvent: { layout: { x, y, width, height } } } 。 |
Function |
ALL |
onLoad | 加载成功完成时调用此回调函数。 | Function |
ALL |
onLoadStart | 加载开始时调用。 例如, onLoadStart={() => this.setState({ loading: true })} |
Function |
ALL |
onLoadEnd | 加载结束后,不论成功还是失败,调用此回调函数。 | Function |
ALL |
resizeMode | 决定当组件尺寸和图片尺寸不成比例的时候如何调整图片的大小。 | enum(cover, contain, stretch, repeat, center) |
ALL |
source | uri是一个表示图片的资源标识的字符串,需要用http路径。 现在支持的图片格式有 png , jpg , jpeg , bmp , gif 。 |
{ uri: string } |
ALL |
defaultSource | 指定当 Image 组件还没加载出来 source 属性指定的图片的占位符图片,当 source 属性指定的图片加载失败时, Image 组件会显示 defaultSource 属性指定的图片 |
string :图片 base64 字符串 |
ALL |
onError | 当加载错误的时候调用此回调函数,参数为 { nativeEvent: { error } } |
Function |
ALL |
capInsets | 当调整 Image 大小的时候,由 capInsets 指定的边角尺寸会被固定而不进行缩放,而中间和边上其他的部分则会被拉伸。这在制作一些可变大小的圆角按钮、阴影、以及其它资源的时候非常有用。 |
{ top: number, left: number, bottom: number, right: number } |
ALL |
onProgress | 在加载过程中不断调用,参数为 { nativeEvent: { loaded, total } } |
Function |
ALL |
onTouchDown | 当用户开始触屏控件时(即用户在该控件上按下手指时),将回调此函数,并将触屏点信息作为参数传递进来; 参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchMove | 当用户在控件移动手指时,此函数会持续收到回调,并通过event参数告知控件的触屏点信息;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchEnd | 当触屏操作结束,用户在该控件上抬起手指时,此函数将被回调,event参数也会通知当前的触屏点信息;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchCancel | 当用户触屏过程中,某个系统事件中断了触屏,例如电话呼入、组件变化(如设置为hidden),此函数会收到回调,触屏点信息也会通过event参数告知前端;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
方法
getSize
(uri: string, success: (width: number, height: number) => void, failure?: ErrorFunction) => void
在显示图片前获取图片的宽高(以像素为单位)。如果图片地址不正确或下载失败, 此方法也会失败。
要获取图片的尺寸, 首先需要加载或下载图片(同时会被缓存起来)。这意味着理论上你可以用这个方法来预加载图片,虽然此方法并没有针对这一用法进行优化,而且将来可能会换一些实现方案使得并不需要完整下载图片即可获取尺寸。所以更好的预加载方案是使用下面那个专门的预加载方法。
不适用于静态图片资源。
uri
: string - 图片的地址success
: (width: number, height: number) => void - 此函数会在获取图片与其宽高成功后被回调failure
: ErrorFunction - 此函数会在如获取图片失败等异常情况被回调
prefetch
(url: string) => void
预加载一个远程图片,将其下载到本地磁盘缓存。
uri
: string - 图片的地址
ListView
可复用垂直列表功能,尤其适合大量条目的数据渲染。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
bounces | 是否开启回弹效果,默认 true |
boolean |
iOS |
overScrollEnabled | 是否开启回弹效果,默认 true |
boolean |
Android |
getRowKey | 指定一个函数,在其中返回对应条目的 Key 值,详见 React 官文 | (index: number) => any |
ALL |
getRowStyle | 设置ListViewItem 容器的样式。当设置了 horizontal=true 启用横向 ListView 时,需显式设置 ListViewItem 宽度 |
(index: number) => styleObject |
ALL |
getRowType | 指定一个函数,在其中返回对应条目的类型(返回Number类型的自然数,默认是0),List 将对同类型条目进行复用,所以合理的类型拆分,可以很好地提升list 性能。 | (index: number) => number |
ALL |
horizontal | 指定 ListView 是否采用横向布局。default: undefined |
any |
Android |
initialListSize | 指定在组件刚挂载的时候渲染多少行数据。用这个属性来确保首屏显示合适数量的数据,而不是花费太多帧时间逐步显示出来。 | number |
ALL |
initialContentOffset | 初始位移值 — 在列表初始化时即可指定滚动距离,避免初始化后再通过 scrollTo 系列方法产生的闪动。Android 在 2.8.0 版本后支持 |
number |
ALL |
onAppear | 当有ListViewItem 滑动进入屏幕时(曝光)触发,入参返回曝光的ListViewItem 对应索引值。 |
(index) => any |
ALL |
onDisappear | 当有ListViewItem 滑动离开屏幕时触发,入参返回离开的ListViewItem 对应索引值。 |
(index) => any |
ALL |
onWillAppear | 当有ListViewItem 至少一个像素进入屏幕时(曝光)触发,入参返回曝光的ListViewItem 对应索引值。 最低支持版本2.3.0 |
(index) => any |
ALL |
onWillDisappear | 当有ListViewItem 至少一个像素滑动离开屏幕时触发,入参返回离开的ListViewItem 对应索引值。 最低支持版本2.3.0 |
(index) => any |
ALL |
onEndReached | 当所有的数据都已经渲染过,并且列表被滚动到最后一条时,将触发 onEndReached 回调。 |
Function |
ALL |
onMomentumScrollBegin | 在 ListView 开始滑动的时候调起 |
Function |
ALL |
onMomentumScrollEnd | 在 ListView 结束滑动的时候调起 |
Function |
ALL |
onScroll | 当触发 ListView 的滑动事件时回调,在 ListView 滑动时回调,因此调用会非常频繁,请使用 scrollEventThrottle 进行频率控制。 注意:ListView 在滚动时会进行组件回收,不要在滚动时对 renderRow() 生成的 ListItemView 做任何 ref 节点级的操作(例如:所有 callUIFunction 和 measureInAppWindow 方法),回收后的节点将无法再进行操作而报错。横向ListView时,Android在 2.8.0 版本后支持 |
(obj: { contentOffset: { x: number, y: number } }) => any |
ALL |
onScrollBeginDrag | 当用户开始拖拽 ListView 时调用。 |
Function |
ALL |
onScrollEndDrag | 当用户停止拖拽 ListView 或者放手让 ListView 开始滑动的时候调用 |
Function |
ALL |
preloadItemNumber | 指定当列表滚动至倒数第几行时触发 onEndReached 回调。 |
number |
ALL |
renderRow | 这里的入参是当前row 的index,在这里可以凭借index 获取到具体这一行单元格的数据,从而决定如何渲染这个单元格。 | (index: number) => Node |
ALL |
rowShouldSticky | 在回调函数,根据传入参数index(ListView单元格的index)返回true或false指定对应的item是否需要使用悬停效果(滚动到顶部时,会悬停在List顶部,不会滚出屏幕)。 | (index: number) => boolean |
ALL |
scrollEventThrottle | 指定滑动事件的回调频率,传入数值指定了多少毫秒(ms)组件会调用一次 onScroll 回调事件 |
number |
ALL |
scrollEnabled | 滑动是否开启。default: true |
boolean |
All |
showScrollIndicator | 是否显示滚动条。 | boolean |
ALL |
renderPullHeader | 设置列表下拉头部(刷新条),配合onHeaderReleased 、onHeaderPulling 和 collapsePullHeader 使用, 参考 DEMO。 |
() => View |
ALL |
onHeaderPulling | 下拉过程中触发, 事件会通过 contentOffset 参数返回拖拽高度,可以根据下拉偏移量做相应的逻辑。 | (obj: { contentOffset: number }) => any |
ALL |
onHeaderReleased | 下拉超过内容高度,松手后触发。 | () => any |
ALL |
editable | 是否可编辑,开启侧滑删除时需要设置为 true 。最低支持版本2.9.0 |
boolean |
iOS |
delText | 侧滑删除文本。最低支持版本2.9.0 |
string |
iOS |
onDelete | 在列表项侧滑删除时调起。最低支持版本2.9.0 |
( nativeEvent: { index: number} ) => void |
iOS |
方法
scrollToContentOffset
(xOffset: number, yOffset: number: animated: boolean) => void
通知 ListView 滑动到某个具体坐标偏移值(offset)的位置。
xOffset
: number - 滑动到 X 方向的 offsetyOffset
: number - 滑动到 Y 方向的 offsetanimated
: boolean - 滑动过程是否使用动画
scrollToIndex
(xIndex: number, yIndex: number: animated: boolean) => void
通知 ListView 滑动到第几个 item。
xIndex
: number - 滑动到 X 方向的第 xIndex 个 itemyIndex
: number - 滑动到 Y 方向的 yIndex 个 itemanimated
: boolean - 滑动过程是否使用动画
collapsePullHeader
() => void
收起刷新条 PullHeader。当设置了renderPullHeader
后,每当下拉刷新结束需要主动调用该方法收回 PullHeader。
Modal
模态弹窗组件。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
animated | 弹出时是否需要带动画 | boolean |
ALL |
animationType | 动画效果 | enum(none, slide, fade, slide_fade) |
ALL |
supportedOrientations | 支持屏幕翻转方向 | enum(portrait, portrait-upside-down, landscape, landscape-left, landscape-right)[] |
ALL |
immersionStatusBar | 是否是沉浸式状态栏。 | boolean |
ALL |
darkStatusBarText | 是否是亮色主体文字,默认字体是黑色的,改成 true 后会认为 Modal 背景为暗色调,字体就会改成白色。 | boolean |
ALL |
onShow | 在Modal 显示时会执行此回调函数。 |
Function |
ALL |
onOrientationChange | 屏幕旋转方向改变时执行会回调 | Function |
ALL |
onRequestClose | 在Modal 请求关闭时会执行此回调函数,一般时在 Android 系统里按下硬件返回按钮时触发,一般要在里面处理关闭弹窗。 |
Function |
ALL |
primaryKey | - | string |
iOS |
onDismiss | - | Function |
iOS |
transparent | 背景是否是透明的 | boolean |
ALL |
visible | 是否显示 | boolean |
ALL |
RefreshWrapper
包裹住 ListView
提供下滑刷新功能的组件.
RefreshWrapper
现在只支持包裹一个ListView
组件,暂不支持别的组件的下滑刷新功能。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
onRefresh | 当RefreshWrapper 执行刷新操作时,会触发到此回调函数 |
Function |
ALL |
getRefresh | 定义刷新栏的视图表现,返回 View , Text 等组件。 |
Function |
ALL |
bounceTime | 指定刷新条收回动画的时长,单位为ms | number |
ALL |
方法
refreshCompleted
() => void
调用此方法,告知 RefreshWrapper 已经刷新完毕,RefreshWrapper 将会收起刷新栏。
startRefresh
() => void
调用此方法,手工告知 RefreshWrapper 开始刷新,展开刷新栏。
ScrollView
滚动视图组件,用于展示不确定高度的内容,它可以将一系列不确定高度的子组件装到一个确定高度的容器中,使用者可通过上下或左右滚动操作查看组件宽高之外的内容。
一个包装了平台的 ScrollView
(滚动视图)的组件,同时还集成了触摸锁定的“响应者”系统。
- 注意:记住 ScrollView 必须有一个确定的高度才能正常工作,因为它实际上所做的就是将一系列不确定高度的子组件装进一个确定高度的容器(通过滚动操作)。要给一个 ScrollView 确定一个高度的话,要么直接给它设置高度(不建议),要么确定所有的父容器都有确定的高度。一般来说我们会给 ScrollView 设置
flex: 1
以使其自动填充父容器的空余空间,但前提条件是所有的父容器本身也设置了flex或者指定了高度,否则就会导致无法正常滚动,你可以使用元素查看器来查找问题的原因。- 注意: ScrollView 无法使用 onTouch 系列事件监听触屏行为,但可以用 onScroll 监听滚动行为。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
bounces | 是否开启回弹效果,默认 true |
boolean |
iOS |
contentContainerStyle | 这些样式会应用到一个内层的内容容器上,所有的子视图都会包裹在内容容器内。 | StyleSheet |
ALL |
horizontal | 当此属性为 true 的时候,所有的子视图会在水平方向上排成一行,而不是默认的在垂直方向上排成一列 |
boolean |
ALL |
onMomentumScrollBegin | 在 ScrollView 滑动开始的时候调起。 |
Function |
ALL |
onMomentumScrollEnd | 在 ScrollView 滑动结束的时候调起。 |
Function |
ALL |
onScroll | 在滚动的过程中,每帧最多调用一次此回调函数。 | Function |
ALL |
onScrollBeginDrag | 当用户开始拖拽 ScrollView 时调用。 |
Function |
ALL |
onScrollEndDrag | 当用户停止拖拽 ScrollView 或者放手让 ScrollView 开始滑动的时候调用。 |
Function |
ALL |
pagingEnabled | 当值为 true 时,滚动条会停在滚动视图的尺寸的整数倍位置。这个可以用在水平分页上。default: false |
boolean |
ALL |
scrollEventThrottle | 指定滑动事件的回调频率,传入数值指定了多少毫秒(ms)组件会调用一次 onScroll 回调事件。 |
number |
ALL |
scrollIndicatorInsets | 决定滚动条距离视图边缘的坐标。这个值应该和contentInset一样。 | { top: number, left: number, bottom: number, right: number } |
ALL |
scrollEnabled | 当值为 false 的时候,内容不能滚动。default: true |
boolean |
ALL |
showScrollIndicator | 是否显示滚动条。 default: false |
boolean |
Android |
showsHorizontalScrollIndicator | 当此值设为 false 的时候,ScrollView 会隐藏水平的滚动条。default: true |
boolean |
iOS |
showsVerticalScrollIndicator | 当此值设为 false 的时候,ScrollView 会隐藏垂直的滚动条。 default: true |
boolean |
iOS |
方法
scrollTo
(x: number, y: number, animated: boolean) => void
滚动到指定的 X,Y 偏移值,第三个参数为是否启用平滑滚动动画。
- x: number - X 偏移值
- y: number - Y 偏移值
- animated: boolean - 是否启用平滑滚动动画。
scrollToWithDuration
(x: number, y: number, duration: number) => void
经过指定的时间平滑滚动到 X、Y 偏移值。
- x: number - X 偏移值
- y: number - Y 偏移值
- duration: number - 毫秒为单位的滚动时间
TextInput
输入文本的基本组件。
本组件的属性提供了多种特性的配置,譬如自动完成、自动大小写、占位文字,以及多种不同的键盘类型(如纯数字键盘)等等。
差异性
由于系统组件层的差异,如果 TextInput 处于会被键盘遮住的位置,在呼出键盘后:
- iOS 则是正常的遮住
- Android 的表现为页面会被键盘顶起,顶起的幅度取决于 TextInput 的 Y 轴位置决定
关于解决此间的平台差异性,我们仍在讨论。
若有 iOS 对齐 Android 的键盘顶起的需求,建议参考 StackOverflow,在业务层解决。
Android 弹出后盖住界面的解决办法
在部分 Android 机型上,键盘弹出后也可能会产生盖住界面的情况,一般情况下可以通过修改 AndroidMainfest.xml
文件,在 activity 上增加 android:windowSoftInputMode=”adjustPan” 解决。
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.tencent.mtt.hippy.example"
>
<application
android:allowBackup="true"
android:label="@string/app_name"
>
<!-- 注意 android:windowSoftInputMode="adjustPan" 写在 activity 的参数里-->
<activity android:name=".MyActivity"
android:windowSoftInputMode="adjustPan"
android:label="@string/activity_name"
android:configChanges="orientation|screenSize"
>
</activity>
</application>
</manifest>
该参数的意义是:
- adjustResize: resize the page content
- adjustPan: move page content without resizing page content
详情请参考 Android 开发文档。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
caretColor | 输入光标颜色。 最低支持版本2.11.5 |
color |
Android |
defaultValue | 提供一个文本框中的初始值。当用户开始输入的时候,值就可以改变。 在一些简单的使用情形下,如果你不想用监听消息然后更新 value 属性的方法来保持属性和状态同步的时候,就可以用 defaultValue 来代替。 | string |
ALL |
editable | 如果为 false,文本框是不可编辑的。 | boolean |
ALL |
keyboardType | 决定弹出的何种软键盘的。 注意,password 仅在属性 multiline=false 单行文本框时生效。 |
enum(default, numeric, password, email, phone-pad) |
ALL |
maxLength | 限制文本框中最多的字符数。使用这个属性而不用JS 逻辑去实现,可以避免闪烁的现象。 | numbers |
ALL |
multiline | 如果为 true ,文本框中可以输入多行文字。 由于终端特性。 |
boolean |
ALL |
numberOfLines | 设置 TextInput 的最大行数,在使用的时候必需同时设置 multiline 参数为 true 。 |
number |
ALL |
onBlur | 当文本框失去焦点的时候调用此回调函数。 | Function |
ALL |
onChangeText | 当文本框内容变化时调用此回调函数。改变后的文字内容会作为参数传递。 | Function |
ALL |
onKeyboardWillShow | 在弹出输入法键盘时候会触发此回调函数,返回值包含键盘高度 keyboardHeight ,样式如 { keyboardHeight: 260} 。仅在 iOS 可用,Android 输入法不会遮挡App画面 |
Function |
iOS |
onEndEditing | 当文本输入结束后调用此回调函数。 | Function |
ALL |
onLayout | 当组件挂载或者布局变化的时候调用,参数为{ x, y, width, height } 。 |
Function |
ALL |
onSelectionChange | 当输入框选择文字的范围被改变时调用。返回参数的样式如 { nativeEvent: { selection: { start, end } } } 。 |
Function |
ALL |
placeholder | 如果没有任何文字输入,会显示此字符串。 | string |
ALL |
placeholderTextColor | 占位字符串显示的文字颜色。 | color |
ALL |
placeholderTextColors | - | color |
ALL |
returnKeyType | 指定软键盘的回车键显示的样式。 | enum(done, go, next, search, send) |
ALL |
underlineColorAndroid | TextInput 下底线的颜色。 可以设置为’transparent’来去掉下底线。 |
string |
Android |
value | 指定 TextInput 组件的值。 |
string |
ALL |
autoFocus | 组件渲染时自动获得焦点。 | boolean |
ALL |
方法
blur
() => void
让指定的 input 或 View 组件失去光标焦点,与 focus() 的作用相反。
clear
() => void
清空输入框的内容。
focus
() => void
指派 TextInput 获得焦点。
getValue
() => Promise<string>
获得文本框中的内容。
hideInputMethod
() => void
隐藏软键盘。
setValue
(value: string) => void
设置文本框内容。
- value: string - 文本框内容
showInputMethod
() => void
显示软键盘。
Text
文本组件。
注意事项
需要注意的是,在 <Text>
中拼接字符串时,推荐使用 ES6 的模板字符串:
<Text>{ `现在时间是 ${new Date().toString()}` }</Text> // ✅
而不是
<Text>现在时间是 { new Date().toString() }</Text> // ❌
后者有可能在数据更新时不会更新界面。
属性
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
numberOfLines | 用来当文本过长的时候裁剪文本。包括折叠产生的换行在内,总的行数不会超过这个属性的限制。 | number |
ALL |
opacity | 配置 View 的透明度,同时会影响子节点的透明度。 |
number |
ALL |
onLayout | 当元素挂载或者布局改变的时候调用,参数为: { nativeEvent: { layout: { x, y, width, height } } } 。 |
Function |
ALL |
onClick | 当文本被点击以后调用此回调函数。 例如, onClick={() => console.log('onClick') } |
Function |
ALL |
ellipsizeMode* | 当设定了 numberOfLines 值后,这个参数指定了字符串如何被截断。所以在使用 ellipsizeMode 时,必须得同时指定 numberOfLines 数值。 |
enum(head, middle, tail, clip) |
Android 仅支持 tail 属性,iOS 全支持 |
onTouchDown | 当用户开始触屏控件时(即用户在该控件上按下手指时),将回调此函数,并将触屏点信息作为参数传递进来; 参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchMove | 当用户在控件移动手指时,此函数会持续收到回调,并通过event参数告知控件的触屏点信息;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchEnd | 当触屏操作结束,用户在该控件上抬起手指时,此函数将被回调,event参数也会通知当前的触屏点信息;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchCancel | 当用户触屏过程中,某个系统事件中断了触屏,例如电话呼入、组件变化(如设置为hidden),此函数会收到回调,触屏点信息也会通过event参数告知前端;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
- ellipsizeMode 的参数含义:
clip
- 超过指定行数的文字会被直接截断,不显示“…”;(仅iOS支持)head
- 文字将会从头开始截断,保证字符串的最后的文字可以正常显示在Text
组件的最后,而从开头给截断的文字,将以 “…” 代替,例如 “…wxyz”;(仅iOS支持)middle
- “文字将会从中间开始截断,保证字符串的最后与最前的文字可以正常显示在Text组件的响应位置,而中间给截断的文字,将以 “…” 代替,例如 “ab…yz”;(仅iOS支持)tail
- 文字将会从最后开始截断,保证字符串的最前的文字可以正常显示在 Text 组件的最前,而从最后给截断的文字,将以 “…” 代替,例如 “abcd…”;
View
最基础的容器组件,它是一个支持Flexbox布局、样式、一些触摸处理、和一些无障碍功能的容器,并且它可以放到其它的视图里,也可以有任意多个任意类型的子视图。不论在什么平台上,View
都会直接对应一个平台的原生视图。
属性
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
accessible | 当此属性为 true 时,表示此视图时一个启用了无障碍功能的元素。启用无障碍的其他属性时,必须优先设置 accessible 为 true 。 |
boolean |
ALL |
accessibilityLabel | 设置当用户与此元素交互时,“读屏器”(对视力障碍人士的辅助功能)阅读的文字。默认情况下,这个文字会通过遍历所有的子元素并累加所有的文本标签来构建。 | node |
ALL |
style | - | View Styles |
ALL |
opacity | 配置 View 的透明度,同时会影响子节点的透明度 |
number |
ALL |
overflow | 指定当子节点内容溢出其父级 View 容器时, 是否剪辑内容 |
enum(visible, hidden) |
ALL |
onLayout | 这个事件会在布局计算完成后立即调用一次,不过收到此事件时新的布局可能还没有在屏幕上呈现,尤其是一个布局动画正在进行中的时候。 | Function |
ALL |
onAttachedToWindow | 这个事件会在节点已经渲染并且添加到容器组件中触发,因为 Hippy 的渲染是异步的,这是很稳妥的执行后续操作的事件。 | Function |
ALL |
onTouchDown | 当用户开始触屏控件时(即用户在该控件上按下手指时),将回调此函数,并将触屏点信息作为参数传递进来; 参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchMove | 当用户在控件移动手指时,此函数会持续收到回调,并通过event参数告知控件的触屏点信息;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchEnd | 当触屏操作结束,用户在该控件上抬起手指时,此函数将被回调,event参数也会通知当前的触屏点信息;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
onTouchCancel | 当用户触屏过程中,某个系统事件中断了触屏,例如电话呼入、组件变化(如设置为hidden),此函数会收到回调,触屏点信息也会通过event参数告知前端;参数为 { nativeEvent: { name, page_x, page_y, id } } |
Function |
ALL |
样式内特殊属性
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
collapsable | Android 里如果一个 View 只用于布局它的子组件,则它可能会为了优化而从原生布局树中移除,因此该节点 DOM 的引用会丢失。 把此属性设为 false 可以禁用这个优化,以确保对应视图在原生结构中存在。 |
boolean |
Android |
ViewPager
支持横滑翻页的容器,它的每一个子容器组件会被视作一个单独的页面,并且会被拉伸宽度至 ViewPager
本身宽度。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
initialPage | 指定一个数字,用于决定初始化后默认显示的页面 index,默认不指定的时候是0 | number |
ALL |
scrollEnabled | 指定 ViewPager 是否可以滑动,默认为 true |
boolean |
ALL |
onPageSelected | 指定一个函数,当 page 被选中时进行回调。回调参数是一个 event 对象,回调参数: position: number - 表示即将滑到的目标 page 的索引 |
(obj: {position: number}) => void |
ALL |
onPageScroll | 指定一个函数,当 page 被滑动时进行回调。回调参数是一个 event 对象,回调参数 position: number - 表示即将滑到的目标 page 的索引,offset: number - 当前被选中的 page 的相对位移,取值范围 -1 到 1 |
(obj: {position: number, offset: number}) => void |
ALL |
onPageScrollStateChanged | 指定一个函数,当 page 的滑动状态改变时进行回调。回调参数: pageScrollState: string - 改变后的状态,idle 表示停止,dragging 表示用户用手拖拽,settling 表示 page 正在滑动 |
(pageScrollState: string) => void |
ALL |
direction | 设置 viewPager 滚动方向,不设置默认横向滚动,设置 vertical 为竖向滚动 |
string |
Android |
方法
setPage
(index: number) => void
通过传入一个index 值(数字),滑动到第 index 个页面(有动画)
- index: number - 指定滑动页面
setPageWithoutAnimation
(index: number) => void
通过传入一个index 值(数字),滑动到第 index 个页面(无动画)
- index: number - 指定滑动页面
WaterfallView
最低支持版本 2.9.0
瀑布流组件。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
numberOfColumns | 瀑布流列数量 , Default: 2 | number |
ALL |
numberOfItems | 瀑布流 item 总个数 | number |
ALL |
columnSpacing | 瀑布流每列之前的水平间距 | number |
ALL |
interItemSpacing | item 间的垂直间距 | number |
ALL |
contentInset | 内容缩进 ,默认值 { top:0, left:0, bottom:0, right:0 } |
Object |
ALL |
renderItem | 这里的入参是当前 item 的 index,在这里可以凭借 index 获取到瀑布流一个具体单元格的数据,从而决定如何渲染这个单元格。 | (index: number) => React.ReactElement |
ALL |
renderBanner | 如何渲染 Banner。 | () => React.ReactElement |
iOS |
getItemStyle | 设置WaterfallItem 容器的样式。 |
(index: number) => styleObject |
ALL |
getItemType | 指定一个函数,在其中返回对应条目的类型(返回Number类型的自然数,默认是0),List 将对同类型条目进行复用,所以合理的类型拆分,可以很好地提升list 性能。 | (index: number) => number |
ALL |
getItemKey | 指定一个函数,在其中返回对应条目的 Key 值,详见 React 官文 | (index: number) => any |
ALL |
preloadItemNumber | 滑动到瀑布流底部前提前预加载的 item 数量 | number |
ALL |
onEndReached | 当所有的数据都已经渲染过,并且列表被滚动到最后一条时,将触发 onEndReached 回调。 |
Function |
ALL |
containPullHeader | 是否包含PullHeader 组件,默认 false ;Android 暂不支持,可暂时用 RefreshWrapper 组件替代 |
boolean |
iOS |
renderPullHeader | 如何渲染 PullHeader ,此时 containPullHeader 默认设置成 true |
() => React.ReactElement |
iOS |
containPullFooter | 是否包含PullFooter 组件,默认 false |
boolean |
ALL |
renderPullFooter | 如何渲染 PullFooter ,此时 containPullFooter 默认设置成 true |
() => React.ReactElement |
ALL |
onScroll | 当触发 WaterFall 的滑动事件时回调。startEdgePos 表示距离 List 顶部边缘滚动偏移量;endEdgePos 表示距离 List 底部边缘滚动偏移量;firstVisibleRowIndex 表示当前可见区域内第一个元素的索引;lastVisibleRowIndex 表示当前可见区域内最后一个元素的索引;visibleRowFrames 表示当前可见区域内所有 item 的信息(x,y,width,height) |
{ nativeEvent: { startEdgePos: number, endEdgePos: number, firstVisibleRowIndex: number, lastVisibleRowIndex: number, visibleRowFrames: Object[] } } |
ALL |
方法
scrollToIndex
(obj: { index: number, animated: boolean }) => void
通知 Waterfall 滑动到第几个 item。
index
: number - 滑动到的第 index 个 itemanimated
: boolean - 滑动过程是否使用动画, 默认true
scrollToContentOffset
(obj: { xOffset: number, yOffset: number, animated: boolean }) => void
通知 Waterfall 滑动到某个具体坐标偏移值(offset)的位置。
xOffset
: number - 滑动到 X 方向的 offsetyOffset
: number - 滑动到 Y 方向的 offsetanimated
: boolean - 滑动过程是否使用动画,默认true
WebView
WebView组件。
参数
参数 | 描述 | 类型 | 支持平台 |
---|---|---|---|
source | Webview 内嵌地址 | { uri: string } |
ALL |
userAgent | Webview userAgent | string |
ALL |
method | 请求方式, get 、post |
string |
ALL |
onLoadStart | 网页开始加载时触发 | (object: { url:string }) => void |
ALL |
onLoad | 网页加载时触发 | (object: { url:string }) => void |
ALL |
onLoadEnd | 网页加载结束时触发 | (object: { url:string }) => void |
ALL |
style | Webview 容器样式 | Object |
ALL |