鸿蒙ArkTS容器组件:【Scroll】

Scroll

可滚动的容器组件,当子组件的布局尺寸超过父组件的尺寸时,内容可以滚动。

说明:
开发前请熟悉鸿蒙开发指导文档gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md点击或者复制转到。

  • 该组件从API version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。
  • 该组件嵌套List子组件滚动时,若List不设置宽高,则默认全部加载,在对性能有要求的场景下建议指定List的宽高。
  • 该组件滚动的前提是主轴方向大小小于内容大小。
  • 该组件回弹的前提是要有滚动。内容小于一屏时,没有回弹效果。

子组件

支持单个子组件。

接口

Scroll(scroller?: Scroller)

参数:

参数名参数类型必填参数描述
scroller[Scroller]可滚动组件的控制器。用于与可滚动组件进行绑定。

属性

除支持[通用属性]外,还支持以下属性:

名称参数类型描述
scrollable[ScrollDirection]设置滚动方向。 默认值:ScrollDirection.Vertical
scrollBar[BarState]设置滚动条状态。 默认值:BarState.Auto 说明: 如果容器组件无法滚动,则滚动条不显示。如果容器组件的子组件大小为无穷大,则滚动条不支持拖动和伴随滚动。
scrollBarColorstringnumber
scrollBarWidthstringnumber
edgeEffect[EdgeEffect]设置滑动效果,目前支持的滑动效果参见EdgeEffect的枚举说明。 默认值:EdgeEffect.None
enableScrollInteraction10+boolean设置是否支持滚动手势,当设置为false时,无法通过手指或者鼠标滚动,但不影响控制器的滚动接口。 默认值:true
friction10+number[Resource]

ScrollDirection枚举说明

名称描述
Horizontal仅支持水平方向滚动。
Vertical仅支持竖直方向滚动。
None不可滚动。

事件

名称功能描述
onScrollFrameBegin9+(event: (offset: number, state: ScrollState) => { offsetRemain })每帧开始滚动时触发,事件参数传入即将发生的滚动量,事件处理函数中可根据应用场景计算实际需要的滚动量并作为事件处理函数的返回值返回,Scroll将按照返回值的实际滚动量进行滚动。 - offset:即将发生的滚动量。 - state:当前滚动状态。 - offsetRemain:实际滚动量。 触发该事件的条件 : 1、滚动组件触发滚动时触发,包括键鼠操作等其他触发滚动的输入设置。 2、调用控制器接口时不触发。 3、越界回弹不触发。 说明: 支持offsetRemain为负值。 若通过onScrollFrameBegine事件和scrollBy方法实现容器嵌套滚动,需设置子滚动节点的EdgeEffect为None。如Scroll嵌套List滚动时,List组件的edgeEffect属性需设置为EdgeEffect.None。
onScroll(event: (xOffset: number, yOffset: number) => void)滚动事件回调, 返回滚动时水平、竖直方向偏移量。 触发该事件的条件 : 1、滚动组件触发滚动时触发,支持键鼠操作等其他触发滚动的输入设置。 2、通过滚动控制器API接口调用。 3、越界回弹。
onScrollEdge(event: (side: Edge) => void)滚动到边缘事件回调。 触发该事件的条件 : 1、滚动组件滚动到边缘时触发,支持键鼠操作等其他触发滚动的输入设置。 2、通过滚动控制器API接口调用。 3、越界回弹。
onScrollStart9+(event: () => void)滚动开始时触发。手指拖动Scroll或拖动Scroll的滚动条触发的滚动开始时,会触发该事件。使用[Scroller]滚动控制器触发的带动画的滚动,动画开始时会触发该事件。 触发该事件的条件 : 1、滚动组件开始滚动时触发,支持键鼠操作等其他触发滚动的输入设置。 2、通过滚动控制器API接口调用后开始,带过渡动效。
onScrollStop9+(event: () => void)滚动停止时触发。手拖动Scroll或拖动Scroll的滚动条触发的滚动,手离开屏幕并且滚动停止时会触发该事件。使用[Scroller]滚动控制器触发的带动画的滚动,动画停止时会触发该事件。 触发该事件的条件 : 1、滚动组件触发滚动后停止,支持键鼠操作等其他触发滚动的输入设置。 2、通过滚动控制器API接口调用后开始,带过渡动效。

说明:

若通过onScrollFrameBegin事件和scrollBy方法实现容器嵌套滚动,需设置子滚动节点的EdgeEffect为None。如Scroll嵌套List滚动时,List组件的edgeEffect属性需设置为EdgeEffect.None。

Scroller

可滚动容器组件的控制器,可以将此组件绑定至容器组件,然后通过它控制容器组件的滚动,同一个控制器不可以控制多个容器组件,目前支持绑定到List、Scroll、ScrollBar、Grid、WaterFlow上。

导入对象

scroller: Scroller = new Scroller()

scrollTo

scrollTo(value: { xOffset: number | string, yOffset: number | string, animation?: { duration?: number, curve?: Curve | ICurve } | boolean }): void

滑动到指定位置。

参数:

参数名参数类型必填参数描述
xOffsetnumberstring
yOffsetnumberstring
animation{ duration?: number, curve?: [Curve][ICurve]10+ }boolean10+

scrollEdge

scrollEdge(value: Edge): void

滚动到容器边缘,不区分滚动轴方向,Edge.Top和Edge.Start表现相同,Edge.Bottom和Edge.End表现相同。

参数:

参数名参数类型必填参数描述
value[Edge]滚动到的边缘位置。

scrollPage

scrollPage(value: { next: boolean }): void

滚动到下一页或者上一页。

参数:

参数名参数类型必填参数描述
nextboolean是否向下翻页。true表示向下翻页,false表示向上翻页。

currentOffset

currentOffset(): { xOffset: number, yOffset: number }

返回当前的滚动偏移量。

返回值

类型描述
{ xOffset: number, yOffset: number }xOffset: 水平滑动偏移; yOffset: 竖直滑动偏移。 说明: 返回值单位为vp。

scrollToIndex

scrollToIndex(value: number, smooth?: boolean, align?: ScrollAlign): void

滑动到指定Index。

开启smooth动效时,会对经过的所有item进行加载和布局计算,当大量加载item时会导致性能问题。

说明:

仅支持Grid、List、WaterFlow组件。

参数:

参数名参数类型必填参数描述
valuenumber要滑动到的目标元素在当前容器中的索引值。 说明: value值设置成负值或者大于当前容器子组件的最大索引值,视为异常值,本次跳转不生效。
smooth10+boolean设置滑动到列表项在列表中的索引值时是否有动效,true表示有动效,false表示没有动效。 默认值:false。 说明: 当前仅List组件支持该参数。
align10+[ScrollAlign]指定滑动到的元素与当前容器的对齐方式。 List中的默认值为:ScrollAlign.START。Grid中默认值为:ScrollAlign.AUTO 说明: 当前仅List、Grid组件支持该参数。

scrollBy9+

scrollBy(dx: Length, dy: Length): void

滑动指定距离。

说明:

仅支持Scroll、ScrollBar、Grid、List组件。

参数:

参数名参数类型必填参数描述
dxLength水平方向滚动距离,不支持百分比形式。
dyLength竖直方向滚动距离,不支持百分比形式。

isAtEnd10+

isAtEnd(): boolean

查询组件是否滚动到底部。

说明:

支持Scroll、List、Grid、WaterFlow组件。

返回值

类型描述
booleantrue表示组件已经滚动到底部,false表示组件还没滚动到底部。

ScrollAlign枚举说明10+

名称描述 HarmonyOS与OpenHarmony鸿蒙文档籽料:mau123789是v直接拿
START首部对齐。指定item首部与List首部对齐。
CENTER居中对齐。指定item主轴方向居中对齐于List。
END尾部对齐。指定item尾部与List尾部对齐。
AUTO自动对齐。 若指定item完全处于显示区,不做调整。否则依照滑动距离最短的原则,将指定item首部对齐或尾部对齐于List,使指定item完全处于显示区。

在这里插入图片描述

示例

示例1

// xxx.ets
import Curves from '@ohos.curves'

@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: number) => {
            Text(item.toString())
              .width('90%')
              .height(150)
              .backgroundColor(0xFFFFFF)
              .borderRadius(15)
              .fontSize(16)
              .textAlign(TextAlign.Center)
              .margin({ top: 10 })
          }, (item: string) => item)
        }.width('100%')
      }
      .scrollable(ScrollDirection.Vertical)  // 滚动方向纵向
      .scrollBar(BarState.On)  // 滚动条常驻显示
      .scrollBarColor(Color.Gray)  // 滚动条颜色
      .scrollBarWidth(10) // 滚动条宽度
      .friction(0.6)
      .edgeEffect(EdgeEffect.None)
      .onScroll((xOffset: number, yOffset: number) => {
        console.info(xOffset + ' ' + yOffset)
      })
      .onScrollEdge((side: Edge) => {
        console.info('To the edge')
      })

      Button('scroll 150')
        .height('5%')
        .onClick(() => { // 点击后下滑指定距离150.0vp
          this.scroller.scrollBy(0,150)
        })
        .margin({ top: 10, left: 20 })
      Button('scroll 100')
        .height('5%')
        .onClick(() => { // 点击后滑动到指定位置,即下滑100.0vp的距离
          const yOffset: number = this.scroller.currentOffset().yOffset;
          this.scroller.scrollTo({ xOffset: 0, yOffset: yOffset + 100 })
        })
        .margin({ top: 60, left: 20 })
      Button('scroll 100')
        .height('5%')
        .onClick(() => { // 点击后滑动到指定位置,即下滑100.0vp的距离,滑动过程配置有动画
          let curve = Curves.interpolatingSpring(100, 1, 228, 30) //创建一个阶梯曲线
          const yOffset: number = this.scroller.currentOffset().yOffset;
          this.scroller.scrollTo({ xOffset: 0, yOffset: yOffset + 100, animation: { duration: 1000, curve: curve } })
        })
        .margin({ top: 110, left: 20 })
      Button('back top')
        .height('5%')
        .onClick(() => { // 点击后回到顶部
          this.scroller.scrollEdge(Edge.Top)
        })
        .margin({ top: 160, left: 20 })
      Button('next page')
        .height('5%')
        .onClick(() => { // 点击后滑到下一页
          this.scroller.scrollPage({ next: true })
        })
        .margin({ top: 210, left: 20 })
    }.width('100%').height('100%').backgroundColor(0xDCDCDC)
  }
}

在这里插入图片描述

示例2

@Entry
@Component
struct NestedScroll {
  @State listPosition: number = 0; // 0代表滚动到List顶部,1代表中间值,2代表滚动到List底部。
  private arr: number[] = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
  private scrollerForScroll: Scroller = new Scroller()
  private scrollerForList: Scroller = new Scroller()

  build() {
    Flex() {
      Scroll(this.scrollerForScroll) {
        Column() {
          Text("Scroll Area")
            .width("100%")
            .height("40%")
            .backgroundColor(0X330000FF)
            .fontSize(16)
            .textAlign(TextAlign.Center)
            .onClick(() => {
              this.scrollerForList.scrollToIndex(5)
            })

          List({ space: 20, scroller: this.scrollerForList }) {
            ForEach(this.arr, (item: number) => {
              ListItem() {
                Text("ListItem" + item)
                  .width("100%")
                  .height("100%")
                  .borderRadius(15)
                  .fontSize(16)
                  .textAlign(TextAlign.Center)
                  .backgroundColor(Color.White)
              }.width("100%").height(100)
            }, (item: string) => item)
          }
          .width("100%")
          .height("50%")
          .edgeEffect(EdgeEffect.None)
          .friction(0.6)
          .onReachStart(() => {
            this.listPosition = 0
          })
          .onReachEnd(() => {
            this.listPosition = 2
          })
          .onScrollFrameBegin((offset: number) => {
            if ((this.listPosition == 0 && offset <= 0) || (this.listPosition == 2 && offset >= 0)) {
              this.scrollerForScroll.scrollBy(0, offset)
              return { offsetRemain: 0 }
            }
            this.listPosition = 1
            return { offsetRemain: offset };
          })

          Text("Scroll Area")
            .width("100%")
            .height("40%")
            .backgroundColor(0X330000FF)
            .fontSize(16)
            .textAlign(TextAlign.Center)
        }
      }
      .width("100%").height("100%")
    }.width('100%').height('100%').backgroundColor(0xDCDCDC).padding(20)
  }
}

在这里插入图片描述

  • 16
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: overflow:scroll 是一个CSS属性,用来设置一个元素在内容超出其容器尺寸时是否显示滚动条。在移动端中,overflow:scroll 有时可能失效的原因有以下几个: 1. 使用的元素不支持滚动:有些元素,比如 `<div>` 或 `<span>`,默认是不支持滚动的,只有设置了特定的CSS属性后才能实现滚动效果。因此,如果在一个不支持滚动的元素上使用 overflow:scroll,是不会有效果的。 2. 缺乏足够的内容:当容器内的内容没有超出容器的尺寸时,即使设置了 overflow:scroll,也不会显示滚动条。因此,检查一下容器内的内容是否足够多,以确保滚动条的显示。 3. 容器尺寸限制:有时,父容器对子容器的尺寸进行了限制,例如设置了固定的高度或宽度,并且没有提供足够的空间来显示滚动条。在这种情况下,即使设置了 overflow:scroll,滚动条依然不会显示。 解决这些问题的方法可能是: 1. 使用支持滚动的元素:如果需要实现滚动效果,可以考虑使用 `<ul>` 或 `<div>` 等支持滚动的元素,并在其上应用 overflow:scroll。 2. 提供足够的内容:确保容器内的内容超出容器的尺寸,以触发滚动条的显示。 3. 调整容器尺寸限制:如果父容器对子容器的尺寸进行了限制,可以尝试调整父容器的大小或使用其他布局方式,以确保滚动条可以正常显示。 除此之外,还有其他可能的原因导致 overflow:scroll 失效,如浏览器或设备的兼容性问题。在实际应用中,我们可以通过调试工具或其他开发者工具来进一步排查和解决该问题。 ### 回答2: overflow:scroll 在移动端失效的原因可能有以下几点: 1. 移动设备的触摸屏幕和滚动机制不同于传统的鼠标滚轮操作,因此浏览器默认禁用了 overflow:scroll 的功能。在移动设备上,用户可以通过手指滑动屏幕的方式来进行页面的滚动。 2. 移动设备的屏幕尺寸较小,因此浏览器在移动端对页面进行了优化,自动将 overflow:scroll 的内容进行了隐藏,并不会出现滚动条。这是为了保证页面在移动设备上可以正常显示,并减少页面占用的空间。 3. 在某些特定的移动浏览器中,可能存在一些兼容性问题,导致 overflow:scroll 失效。这可能是由于浏览器对 CSS 的支持程度不同或者存在一些 bug。 针对以上情况,我们可以通过以下方法来解决移动端下 overflow:scroll 失效的问题: 1. 使用移动端特有的滚动区域组件,例如提供了滚动功能的第三方组件(如 iScroll、better-scroll 等)来替代原生的 overflow:scroll。 2. 使用 CSS 属性 -webkit-overflow-scrolling: touch; 来启用移动设备的滚动效果。这个属性可以告诉浏览器在滚动区域内使用硬件加速的方式进行滚动,提升性能和流畅度。 3. 对于需要在移动端实现滚动效果的特定场景,可以考虑使用 position:fixed; 来固定页面的某个区域,并结合 touch 事件来实现自定义的滚动效果。 总结来说,overflow:scroll 在移动端失效主要是因为浏览器默认禁用了该功能或者移动设备的屏幕尺寸较小无法正常显示。我们可以借助特定的滚动组件或者 CSS 属性来实现移动端的滚动效果。 ### 回答3: overflow:scroll 是 CSS 属性,用于控制元素溢出内容时的滚动行为。在移动端中,有时会遇到 overflow:scroll 失效的情况。 造成 overflow:scroll 失效的可能原因有以下几种: 1. 元素没有定义固定的高度或宽度:在移动端,由于屏幕大小不一致,如果元素没有定义明确的高度或宽度,浏览器无法确定内容何时溢出,因此 overflow:scroll 属性可能无效。 解决方法:确保元素设置了固定的高度或宽度,如通过设置 height 或者 width 属性来约束元素的尺寸。这样浏览器就能根据内容是否溢出来决定是否显示滚动条。 2. 浏览器不支持滚动:在某些移动端浏览器中,特别是一些老旧的浏览器,可能不支持 overflow:scroll 属性。 解决方法:可以使用 Javascript 或者专门的滚动插件来实现滚动效果,或者尝试使用其他浏览器测试是否支持滚动属性。 3. 元素的位置固定或绝对定位:如果元素的定位方式为 fixed 或者 absolute,overflow:scroll 属性可能会失效。 解决方法:将元素的定位方式修改为 relative 或 static,或者在父级元素上设置 overflow 属性。 总结来说,在移动端中,如果遇到 overflow:scroll 失效的问题,需要确保元素定义了固定的高度或者宽度,浏览器支持滚动属性,以及元素的定位方式是否符合要求。如果仍然无法解决问题,可以尝试使用其他解决方案来实现滚动效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值