HarmonyOS-UIAbitity-StepperItem——【坚果派-红目香薰】

简介: HarmonyOS-UIAbitity-StepperItem——【坚果派-红目香薰】

摘要

作者:红目香薰

团队:坚果派

团队介绍:坚果派由坚果创建,团队拥有12个华为HDE以及若干其他领域的三十余位万粉博主运营。

StepperItem

用作Stepper组件的页面子组件。

子组件

支持单个子组件。

接口

StepperItem()

属性

参数名

参数类型

默认值

参数描述

prevLabel

string

-

当步骤导航器大于一页,除第一页默认值都为"返回"。

nextLabel

string

-

步骤导航器大于一页时,最后一页默认值为"开始",其余页默认值为"下一步"。

status

ItemState

ItemState.Normal

步骤导航器元素的状态。

ItemState枚举说明

名称

描述

Normal

正常状态,右侧文本按钮正常显示,可点击进入下一个StepperItem。

Disabled

不可用状态,右侧文本按钮灰度显示,不可点击进入下一个StepperItem。

Waiting

等待状态,右侧文本按钮不显示,使用等待进度条,不可点击进入下一个StepperItem。

Skip

跳过状态,表示跳过当前步骤, 进入下一个StepperItem。

示例代码

 

@Entry

@Component

struct Index {

 @State currentIndex: number = 0;

 @State firstState: ItemState = ItemState.Normal;

 @State secondState: ItemState = ItemState.Normal;

 @State thirdState: ItemState = ItemState.Normal;

 build() {

   Stepper({

     index: this.currentIndex

   }) {

     // 第一个步骤页

     StepperItem() {

       Column() {

         Text('Page One')

           .fontSize(35)

           .fontColor(Color.Blue)

           .lineHeight(50)

           .margin({ top: 250, bottom: 50 })

         Button('change status:' + this.firstState)

           .onClick(() => {

             this.firstState = this.firstState === ItemState.Skip ? ItemState.Normal : ItemState.Skip;

           })

       }.width('100%')

     }

     .nextLabel('Next')

     .status(this.firstState)

     // 第二个步骤页

     StepperItem() {

       Column() {

         Text('Page Two')

           .fontSize(35)

           .fontColor(Color.Blue)

           .lineHeight(50)

           .margin({ top: 250, bottom: 50 })

         Button('change status:' + this.secondState)

           .onClick(() => {

             this.secondState = this.secondState === ItemState.Disabled ? ItemState.Normal : ItemState.Disabled;

           })

       }.width('100%')

     }

     .nextLabel('Next')

     .prevLabel('Previous')

     .status(this.secondState)

     // 第三个步骤页

     StepperItem() {

       Column() {

         Text('Page Three')

           .fontSize(35)

           .fontColor(Color.Blue)

           .lineHeight(50)

           .margin({ top: 250, bottom: 50 })

         Button('change status:' + this.thirdState)

           .onClick(() => {

             this.thirdState = this.thirdState === ItemState.Waiting ? ItemState.Normal : ItemState.Waiting;

           })

       }.width('100%')

     }

     .status(this.thirdState)

     // 第四个步骤页

     StepperItem() {

       Text('Page four')

         .fontSize(35)

         .fontColor(Color.Blue)

         .width('100%')

         .textAlign(TextAlign.Center)

         .lineHeight(50)

         .margin({ top: 250 })

     }

     .nextLabel('Finish')

   }

   .onFinish(() => {

     // 此处可处理点击最后一页的Finish时的逻辑,例如路由跳转等

     console.info('onFinish');

   })

   .onSkip(() => {

     // 此处可处理点击跳过时的逻辑,例如动态修改Stepper的index值使其跳转到某一步骤页等

     console.info('onSkip');

   })

   .onChange((prevIndex: number, index: number) => {

     this.currentIndex = index;

   })

 }

}

实际效果:

相关文章
|
7月前
|
数据安全/隐私保护
HarmonyOS-UIAbitity-TextArea——【坚果派-红目香薰】
HarmonyOS-UIAbitity-TextArea——【坚果派-红目香薰】
55 0
|
7月前
HarmonyOS-UIAbitity-Text——【坚果派-红目香薰】
HarmonyOS-UIAbitity-Text——【坚果派-红目香薰】
37 0
|
7月前
|
索引
HarmonyOS-UIAbitity-Stepper——【坚果派-红目香薰】
HarmonyOS-UIAbitity-Stepper——【坚果派-红目香薰】
43 0
|
7月前
HarmonyOS-UIAbitity-Span——【坚果派-红目香薰】
HarmonyOS-UIAbitity-Span——【坚果派-红目香薰】
50 0
|
7月前
HarmonyOS-UIAbitity-Slider——【坚果派-红目香薰】
HarmonyOS-UIAbitity-Slider——【坚果派-红目香薰】
41 0
|
7月前
|
索引
HarmonyOS-UIAbitity-Select——【坚果派-红目香薰】
HarmonyOS-UIAbitity-Select——【坚果派-红目香薰】
44 0
|
13天前
|
存储 人工智能 JavaScript
Harmony OS开发-ArkTS语言速成二
本文介绍了ArkTS基础语法,包括三种基本数据类型(string、number、boolean)和变量的使用。重点讲解了let、const和var的区别,涵盖作用域、变量提升、重新赋值及初始化等方面。期待与你共同进步!
73 47
Harmony OS开发-ArkTS语言速成二
|
15天前
|
API 索引
鸿蒙开发:实现一个超简单的网格拖拽
实现拖拽,最重要的三个方法就是,打开编辑状态editMode,实现onItemDragStart和onItemDrop,设置拖拽移动动画和交换数据,如果想到开启补位动画,还需要实现supportAnimation方法。
71 13
鸿蒙开发:实现一个超简单的网格拖拽
|
14天前
|
索引 API
鸿蒙开发:自定义一个股票代码选择键盘
金融类的软件,特别是股票基金类的应用,在查找股票的时候,都会有一个区别于正常键盘的键盘,也就是股票代码键盘,和普通键盘的区别就是,除了常见的数字之外,也有一些常见的股票代码前缀按钮,方便在查找股票的时候,更加方便的进行检索。
鸿蒙开发:自定义一个股票代码选择键盘
|
14天前
|
API
鸿蒙开发:自定义一个英文键盘
实现方式呢,有很多种,目前采用了比较简单的一种,如果大家采用网格Grid组件实现方式,也是可以的,但是需要考虑每行的边距以及数据,还有最后两行的格子占位问题。
鸿蒙开发:自定义一个英文键盘