
说明:
该组件从API version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
可滚动的容器组件,当子组件的布局尺寸超过父组件的视口时,内容可以滚动。
接口
Scroll(scroller?: Scroller)
属性

Scroller
可滚动容器组件的控制器,可以将此组件绑定至容器组件,然后通过它控制容器组件的滚动,目前支持绑定到List和Scroll组件上。
导入对象
.scroller: Scroller = new Scroller()
scroller.scrollTo
scrollTo(value: { xOffset: number | string, yOffset: number | string, animation?: { duration: number, curve: Curve } }): void
滑动到指定位置。
scroller.scrollEdge
scrollEdge(value: Edge): void
滚动到容器边缘。
scroller.scrollPage
scrollPage(value: { next: boolean}): void
滚动到下一页或者上一页。
scroller.currentOffset
scroller.currentOffset(): Object
返回当前的滚动偏移量。
scroller.scrollToIndex
scroller.scrollToIndex(value: number): void
滑动到指定Index。
事件

示例:
@Entry
@Component
struct ScrollExample {
scroller: Scroller = new Scroller()
private arr: number[] = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
build() {
Stack({ alignContent: Alignment.TopStart }) {
Scroll(this.scroller) {
Column() {
ForEach(this.arr, (item) => {
Text(item.toString())
.width('90%').height(150).backgroundColor(0xFFFFFF)
.borderRadius(15).fontSize(16).textAlign(TextAlign.Center)
.margin({ top: 10 })
}, item => item)
}.width('100%')
}
.scrollable(ScrollDirection.Vertical).scrollBar(BarState.On)
.scrollBarColor(Color.Gray).scrollBarWidth(30)
.onScroll((xOffset: number, yOffset: number) => {
console.info(xOffset + ' ' + yOffset)
})
.onScrollEdge((side: Edge) => {
console.info('To the edge')
})
.onScrollEnd(() => {
console.info('Scroll Stop')
})
Button('滑动')
.onClick(() => { // 点击后下滑100.0距离
this.scroller.scrollTo({ xOffset: 0, yOffset: this.scroller.currentOffset().yOffset + 100 })
})
.margin({ top: 10, left: 20 })
Button('返回顶部')
.onClick(() => { // 点击后回到顶部
this.scroller.scrollEdge(Edge.Top)
})
.margin({ top: 60, left: 20 })
Button('下一页')
.onClick(() => { // 点击后下滑到底部
this.scroller.scrollPage({ next: true })
})
.margin({ top: 110, left: 20 })
}.width('100%').height('100%').backgroundColor(0xDCDCDC)
}
}
审核编辑:汤梓红
-
Version
+关注
关注
0文章
32浏览量
8028 -
组件
+关注
关注
1文章
600浏览量
19065 -
HarmonyOS
+关注
关注
80文章
2157浏览量
36280
发布评论请先 登录
钉钉正式开源HarmonyOS图片编辑组件
【HarmonyOS 5】鸿蒙中进度条的使用详解
【HarmonyOS 5】鸿蒙页面和组件生命周期函数
【 HarmonyOS 5 入门系列 】鸿蒙HarmonyOS示例项目讲解
LoadingProgress组件的使用##HarmonyOS应用开发##
HarmonyOS NEXT应用元服务布局优化长列表使用懒加载与组件复用
HarmonyOS入门指南
HarmonyOS实战:Tab顶部滑动悬停功能实现
华为正式启动HarmonyOS 6开发者Beta
HarmonyOS 代码工坊的指尖开发,让 APP 开发所见即所得
HarmonyOS基础组件:Button三种类型的使用
HarmonyOS实战:组件化项目搭建
京东开源Taro on HarmonyOS C-API版本
HarmonyOS应用开发-ETSsrcoll滑动组件
评论