鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Scroll)

这篇具有很好参考价值的文章主要介绍了鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Scroll)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

说明:

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

子组件

支持单个子组件。

接口

Scroll(scroller?: Scroller)

参数:

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

属性

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

名称 参数类型 描述
scrollable ScrollDirection 设置滚动方向。
默认值:ScrollDirection.Vertical
scrollBar BarState 设置滚动条状态。
默认值:BarState.Auto
说明:
如果容器组件无法滚动,则滚动条不显示。如果容器组件的子组件大小为无穷大,则滚动条不支持拖动和伴随滚动。
scrollBarColor string | number | Color 设置滚动条的颜色。
scrollBarWidth string | number 设置滚动条的宽度,不支持百分比设置。
默认值:4
单位:vp
说明:
如果滚动条的宽度超过其高度,则滚动条的宽度会变为默认值。
scrollSnap10+ ScrollSnapOptions 设置Scroll组件的限位滚动模式。
edgeEffect value:EdgeEffect,
options?:EdgeEffectOptions11+
设置边缘滑动效果。
- value:设置Scroll组件的边缘滑动效果,支持弹簧效果和阴影效果。
默认值:EdgeEffect.None
- options:设置组件内容大小小于组件自身时,是否开启滑动效果。
默认值:true
enableScrollInteraction10+ boolean 设置是否支持滚动手势,当设置为false时,无法通过手指或者鼠标滚动,但不影响控制器的滚动接口。
默认值:true
nestedScroll10+ NestedScrollOptions 嵌套滚动选项。设置向前向后两个方向上的嵌套滚动模式,实现与父组件的滚动联动。
friction10+ number | Resource 设置摩擦系数,手动划动滚动区域时生效,只对惯性滚动过程有影响,对惯性滚动过程中的链式效果有间接影响。
默认值:非可穿戴设备为0.6,可穿戴设备为0.9
说明:
设置为小于等于0的值时,按默认值处理
enablePaging11+ boolean 设置是否支持划动翻页。
默认值:false
说明:
如果同时设置了划动翻页enablePaging和限位滚动scrollSnap,则scrollSnap优先生效,enablePaging不生效。

ScrollDirection枚举说明

名称 描述
Horizontal 仅支持水平方向滚动。
Vertical 仅支持竖直方向滚动。
None 不可滚动。
Free(deprecated) 支持竖直或水平方向滚动
从API version 9开始废弃

ScrollSnapOptions10+

名称 参数类型 必填 描述
snapAlign ScrollSnapAlign 设置Scroll组件限位滚动时的对其方式。
说明:
1.该属性默认值为ScrollSnapAlign.NONE。
2.该接口仅当snapPagination属性为Dimension时生效,不支持Array<Dimension>。
snapPagination Dimension | Array<Dimension> 设置Scroll组件限位滚动时的限位点,限位点即为Scroll组件能滑动停靠的偏移量。
说明:
1.当属性为Dimension时,表示每页的大小,系统会按照该大小来自动计算每个限位点的位置:如当Dimension为500时,实际的限位点即为[0,500,1000,1500,...]。
2.当属性为Array<Dimension>时,每个Dimension代表限位点的位置。每个Dimension的范围为[0,可滑动距离],0和可滑动距离的底部自动成为限位点。
3.当该属性不填或者Dimension为小于等于0的输入时,按异常值,无限位滚动处理。当该属性值为Array<Dimension>数组时,数组中的数值必须为单调递增。
4.当输入为百分比时,实际的大小为Scroll组件的视口与百分比数值之积。
enableSnapToStart boolean 在Scroll组件限位滚动模式下,该属性设置为false后,运行Scroll在开头和第一个限位点间自由滑动。
说明:
1.该属性值默认为true。
2.该属性仅当snapPagination属性为Array<Dimension>时生效,不支持Dimension。
enableSnapToEnd boolean 在Scroll组件限位滚动模式下,该属性设置为false后,运行Scroll在最后一个限位点和末尾间自由滑动。
说明:
1.该属性值默认为true。
2.该属性仅当snapPagination属性为Array<Dimension>时生效,不支持Dimension。

事件

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

说明:

若通过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

滑动到指定位置。

参数:

参数名 参数类型 必填 参数描述
xOffset number | string 水平滑动偏移。
说明:
该参数值不支持设置百分比。
当值小于0时,不带动画的滚动,按0处理。带动画的滚动,滚动到起始位置后停止。
仅滚动轴为x轴时生效。
yOffset number | string 垂直滑动偏移。
说明:
该参数值不支持设置百分比。
当值小于0时,不带动画的滚动,按0处理。带动画的滚动,滚动到起始位置后停止。
仅滚动轴为y轴时生效。
animation {duration?: number, curve?: Curve | ICurve10+ } | boolean10+ 动画配置:
- duration: 滚动时长设置。
- curve: 滚动曲线设置。
- boolean: 使能默认弹簧动效。
默认值:
{
duration: 1000,
curve: Curve.Ease
}
boolean: false
说明:
设置为小于0的值时,按默认值显示。
当前List、Scroll、Grid、WaterFlow均支持boolean类型和ICurve曲线。

scrollEdge

scrollEdge(value: Edge): void

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

参数:

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

scrollPage9+

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

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

参数:

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

scrollPage(deprecated)

参数名 参数类型 必填 参数描述
next boolean 是否向下翻页。true表示向下翻页,false表示向上翻页。
direction Axis 设置滚动方向为水平或竖直方向。

currentOffset

currentOffset(): OffsetResult

类型 描述
OffsetResult11+ 返回当前的滚动偏移量。
说明:
当scroller控制器未绑定容器组件或者容器组件被异常释放时,currentOffset的返回值为空。

scrollToIndex

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

滑动到指定Index。

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

说明:

仅支持Grid、List、WaterFlow组件。

参数:

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

scrollBy9+

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

滑动指定距离。

说明:

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

参数:

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

isAtEnd10+

isAtEnd(): boolean

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

说明:

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

返回值

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

getItemRect11+

getItemRect(index: number): RectResult

获取子组件的大小位置。

说明:

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

参数:

参数名 参数类型 必填 参数描述
index number 子组件的索引值。

说明:

  • index必须是当前显示区域显示的子组件的索引值,否则视为非法值。
  • 非法值返回的大小和位置均为0。

返回值:

类型 说明
RectResult 子组件的大小和相对于组件的位置。

OffsetResult11+

名称 类型 描述
xOffset number 水平滑动偏移;
返回值单位为vp。
yOffset number 竖直滑动偏移。
返回值单位为vp。

ScrollAlign10+枚举说明

名称 描述
START 首部对齐。指定item首部与List首部对齐。
CENTER 居中对齐。指定item主轴方向居中对齐于List。
END 尾部对齐。指定item尾部与List尾部对齐。
AUTO 自动对齐。
若指定item完全处于显示区,不做调整。否则依照滑动距离最短的原则,将指定item首部对齐或尾部对齐于List,使指定item完全处于显示区。

NestedScrollOptions10+对象说明

名称 类型 必填 描述
scrollForward NestedScrollMode 可滚动组件往末尾端滚动时的嵌套滚动选项。
scrollBackward NestedScrollMode 可滚动组件往起始端滚动时的嵌套滚动选项。

NestedScrollMode10+枚举说明

名称 描述
SELF_ONLY 只自身滚动,不与父组件联动。
SELF_FIRST 自身先滚动,自身滚动到边缘以后父组件滚动。父组件滚动到边缘以后,如果父组件有边缘效果,则父组件触发边缘效果,否则子组件触发边缘效果。
PARENT_FIRST 父组件先滚动,父组件滚动到边缘以后自身滚动。自身滚动到边缘后,如果有边缘效果,会触发自身的边缘效果,否则触发父组件的边缘效果。
PARALLEL 自身和父组件同时滚动,自身和父组件都到达边缘以后,如果自身有边缘效果,则自身触发边缘效果,否则父组件触发边缘效果。

EdgeEffectOptions11+对象说明

参数名 类型 必填 描述
alwaysEnabled boolean 组件内容大小小于组件自身时,设置是否开启滑动效果

示例

示例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')
      })
      .onScrollEnd(() => {
        console.info('Scroll Stop')
      })

      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(10, 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)
  }
}

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

示例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)
  }
}

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

示例3

@Entry
@Component
struct StickyNestedScroll {
  @State message: string = 'Hello World'
  @State arr: number[] = []

  @Styles
  listCard() {
    .backgroundColor(Color.White)
    .height(72)
    .width("100%")
    .borderRadius(12)
  }

  build() {
    Scroll() {
      Column() {
        Text("Scroll Area")
          .width("100%")
          .height("40%")
          .backgroundColor('#0080DC')
          .textAlign(TextAlign.Center)
        Tabs({ barPosition: BarPosition.Start }) {
          TabContent() {
            List({ space: 10 }) {
              ForEach(this.arr, (item: number) => {
                ListItem() {
                  Text("item" + item)
                    .fontSize(16)
                }.listCard()
              }, (item: string) => item)
            }.width("100%")
            .edgeEffect(EdgeEffect.Spring)
            .nestedScroll({
              scrollForward: NestedScrollMode.PARENT_FIRST,
              scrollBackward: NestedScrollMode.SELF_FIRST
            })
          }.tabBar("Tab1")

          TabContent() {
          }.tabBar("Tab2")
        }
        .vertical(false)
        .height("100%")
      }.width("100%")
    }
    .edgeEffect(EdgeEffect.Spring)
    .friction(0.6)
    .backgroundColor('#DCDCDC')
    .scrollBar(BarState.Off)
    .width('100%')
    .height('100%')
  }

  aboutToAppear() {
    for (let i = 0; i < 30; i++) {
      this.arr.push(i)
    }
  }
}

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

示例4

@Entry
@Component
struct Index {
  scroller: Scroller = new Scroller;
  private arr: number[] = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]
  build() {
    Scroll(this.scroller) {
      Column() {
        ForEach(this.arr, (item: number) => {
          Text(item.toString())
            .width('90%')
            .height(200)
            .backgroundColor(0xFFFFFF)
            .borderWidth(1)
            .borderColor(Color.Black)
            .borderRadius(15)
            .fontSize(16)
            .textAlign(TextAlign.Center)
        }, (item: string) => item)
      }.width('100%').backgroundColor(0xDCDCDC)
    }
    .backgroundColor(Color.Yellow)
    .height('100%')
    .edgeEffect(EdgeEffect.Spring)
    .scrollSnap({snapAlign:ScrollSnapAlign.START, snapPagination:400, enableSnapToStart:true, enableSnapToEnd:true})
  }
}

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

最后,有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(HarmonyOS NEXT)资料用来跟着学习是非常有必要的。 

这份鸿蒙(HarmonyOS NEXT)资料包含了鸿蒙开发必掌握的核心知识要点,内容包含了ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(HarmonyOS NEXT)技术知识点。

希望这一份鸿蒙学习资料能够给大家带来帮助,有需要的小伙伴自行领取,限时开源,先到先得~无套路领取!!

获取这份完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料

鸿蒙(HarmonyOS NEXT)最新学习路线

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

  •  HarmonOS基础技能

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

  • HarmonOS就业必备技能 鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI
  •  HarmonOS多媒体技术

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

  • 鸿蒙NaPi组件进阶

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

  • HarmonOS高级技能

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

  • 初识HarmonOS内核 鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI
  • 实战就业级设备开发

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

有了路线图,怎么能没有学习资料呢,小编也准备了一份联合鸿蒙官方发布笔记整理收纳的一套系统性的鸿蒙(OpenHarmony )学习手册(共计1236页)鸿蒙(OpenHarmony )开发入门教学视频,内容包含:ArkTS、ArkUI、Web开发、应用模型、资源分类…等知识点。

获取以上完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料

《鸿蒙 (OpenHarmony)开发入门教学视频》

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

《鸿蒙生态应用开发V2.0白皮书》

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

《鸿蒙 (OpenHarmony)开发基础到实战手册》

OpenHarmony北向、南向开发环境搭建

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

 《鸿蒙开发基础》

  • ArkTS语言
  • 安装DevEco Studio
  • 运用你的第一个ArkTS应用
  • ArkUI声明式UI开发
  • .……

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

 《鸿蒙开发进阶》

  • Stage模型入门
  • 网络管理
  • 数据管理
  • 电话服务
  • 分布式应用开发
  • 通知与窗口管理
  • 多媒体技术
  • 安全技能
  • 任务管理
  • WebGL
  • 国际化开发
  • 应用测试
  • DFX面向未来设计
  • 鸿蒙系统移植和裁剪定制
  • ……

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

《鸿蒙进阶实战》

  • ArkTS实践
  • UIAbility应用
  • 网络案例
  • ……

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI

 获取以上完整鸿蒙HarmonyOS学习资料,请点击→纯血版全套鸿蒙HarmonyOS学习资料

总结

总的来说,华为鸿蒙不再兼容安卓,对中年程序员来说是一个挑战,也是一个机会。只有积极应对变化,不断学习和提升自己,他们才能在这个变革的时代中立于不败之地。 

鸿蒙 edgeeffect,鸿蒙,鸿蒙-ArkTS,harmonyos,华为,android,鸿蒙,鸿蒙系统,ArkTS,ArkUI文章来源地址https://www.toymoban.com/news/detail-850216.html

到了这里,关于鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Scroll)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:Search)

    搜索框组件,适用于浏览器的搜索内容输入框等应用场景。 说明: 该组件从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 无 Search(options?: { value?: string, placeholder?: ResourceStr, icon?: string, controller?: SearchController }) 参数: 参数名 参数类型

    2024年03月24日
    浏览(59)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:文本通用)

    文本通用属性目前只针对包含文本元素的组件,设置文本样式。 说明: 从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 名称 参数类型 描述 fontColor ResourceColor 设置字体颜色。 从API version 9开始,该接口支持在ArkTS卡片中使用。 fon

    2024年03月23日
    浏览(51)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(自定义事件分发)

    ArkUI在处理触屏事件时,会在触屏事件触发前进行按压点和组件区域的触摸测试,来收集需要响应触屏事件的组件,再基于触摸测试结果分发相应的触屏事件。在父节点,开发者可以通过onChildTouchTest决定如何让子节点去做触摸测试,影响子组件的触摸测试,最终影响后续的触

    2024年04月14日
    浏览(58)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:组件标识)

    id为组件的唯一标识,在整个应用内唯一。本模块提供组件标识相关接口,可以获取指定id组件的属性,也提供向指定id组件发送事件的功能。 说明: 从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 名称 参数说明 描述 id string 组件

    2024年04月22日
    浏览(67)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:边框设置)

    设置组件边框样式。 说明: 从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 border(value: BorderOptions) 设置边框样式。 卡片能力:  从API version 9开始,该接口支持在ArkTS卡片中使用。 系统能力:  SystemCapability.ArkUI.ArkUI.Full 参数: 参数

    2024年04月23日
    浏览(55)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:安全区域)

    安全区域是指页面的显示区域,默认不与系统设置的非安全区域比如状态栏、导航栏区域重叠,默认情况下开发者开发的界面都被布局在安全区域内。提供属性方法允许开发者设置组件绘制内容突破安全区域的限制,通过expandSafeArea属性支持组件不改变布局情况下扩展其绘制

    2024年04月29日
    浏览(43)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:尺寸设置)

    用于设置组件的宽高、边距。 说明: 从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 width(value: Length) 设置组件自身的宽度,缺省时使用元素自身内容需要的宽度。若子组件的宽大于父组件的宽,则会画出父组件的范围。 从API ver

    2024年03月15日
    浏览(87)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:Checkbox)

    提供多选框组件,通常用于某选项的打开或关闭。 说明: API version 11开始,Checkbox默认样式由圆角方形变为圆形。 该组件从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 无 Checkbox(options?: CheckboxOptions) 多选框组件。 卡片能力:  从

    2024年04月11日
    浏览(53)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:ImageAnimator)

    提供帧动画组件来实现逐帧播放图片的能力,可以配置需要播放的图片列表,每张图片可以配置时长。 说明: 该组件从API Version 7开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。 无 ImageAnimator() 从API version 10开始,该接口支持在ArkTS卡片中使用。

    2024年03月15日
    浏览(53)
  • 鸿蒙Harmony应用开发—ArkTS声明式开发(基础手势:Web)下篇

    onRequestSelected onRequestSelected(callback: () = void) 当Web组件获得焦点时触发该回调。 示例: onScreenCaptureRequest10+ onScreenCaptureRequest(callback: (event?: { handler: ScreenCaptureHandler }) = void) 通知收到屏幕捕获请求。 参数: 参数名 参数类型 参数描述 handler ScreenCaptureHandler 通知Web组件用户操作行

    2024年04月09日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包