# Stepper 当一个任务需要多个步骤时,可以使用stepper组件展示当前进展。具体用法请参考[Stepper API](../reference/arkui-js/js-components-container-stepper.md)。 > ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:** > 从API Version 5 开始支持。 ## 创建Stepper组件 在pages/index目录下的hml文件中创建一个Stepper组件。 ```
Step 1 Step 2
``` ``` /* xxx.css */ .container { flex-direction: column; justify-content: center; align-items: center; background-color: #F1F3F5; } text{ width: 100%; height: 100%; text-align: center; } ``` ![zh-cn_image_0000001210951235](figures/zh-cn_image_0000001210951235.gif) ## 设置index属性 页面默认显示索引值为index的步骤。 ```
stepper-item1 stepper-item2 stepper-item3
``` ``` /* index.css */ .container { flex-direction: column; background-color:#F1F3F5; } text{ width: 100%; height: 100%; text-align: center; } ``` ![zh-cn_image_0000001208892613](figures/zh-cn_image_0000001208892613.gif) 通过设置label属性,自定义stepper-item的提示按钮。 ```
stepper-item1 stepper-item2 stepper-item3 stepper-item4
``` ``` /* index.css */ .container { flex-direction: column; background-color:#F1F3F5; } text{ width: 100%; height: 100%; text-align: center; } ``` ``` /* index.js */ export default { data: { label_1:{ nextLabel: 'NEXT', status: 'normal' }, label_2:{ prevLabel: 'BACK', nextLabel: 'NEXT', status: 'normal' }, label_3:{ prevLabel: 'BACK', nextLabel: 'END', status: 'disabled' }, }, } ``` ![zh-cn_image_0000001163531210](figures/zh-cn_image_0000001163531210.gif) ## 设置样式 Stepper组件默认填充父容器,通过border和background-color设置边框、背景色。 ```
stepper-item1
``` ``` /* index.css */ .container { flex-direction: column; align-items: center; justify-content: center; background-color:#F1F3F5; } .stepperContent{ width: 300px; height: 300px; } .stepperClass{ border:1px solid silver ; background-color: white; } text{ width: 100%; height: 100%; text-align: center; } ``` ![zh-cn_image_0000001163691154](figures/zh-cn_image_0000001163691154.png) ## 添加事件 Stepper分别添加finish,change,next,back,skip事件。 - 当change与next或back同时存在时,会先执行next或back事件再去执行change事件。 - 重新设置index属性值时要先清除index的值再重新设置,否则检测不到值的改变。 ```
stepper-item1 stepper-item2 stepper-item3
``` ``` /* xxx.css */ .doc-page { flex-direction: column; align-items: center; justify-content: center; } stepper-item{ width: 100%; flex-direction: column; align-self: center; justify-content: center; } text{ margin-top: 45%; justify-content: center; align-self: center; margin-bottom: 50px; } button{ width: 80%; height: 60px; margin-top: 20px; } ``` ``` /* index.js */ import prompt from '@system.prompt'; export default { data: { index:0, }, stepperSkip(){ this.index = null; this.index=2; }, skipClick(){ this.$element('stepperId').setNextButtonStatus({status: 'skip', label: 'SKIP'}); }, stepperFinish(){ prompt.showToast({ message: 'All Finished' }) }, stepperChange(e){ console.log("stepperChange"+e.index) prompt.showToast({ message: 'Previous step: '+e.prevIndex+"-------Current step:"+e.index }) }, stepperNext(e){ console.log("stepperNext"+e.index) prompt.showToast({ message: 'Current step:'+e.index+"-------Next step:"+e.pendingIndex }) var index = {pendingIndex:e.pendingIndex } return index; }, stepperBack(e){ console.log("stepperBack"+e.index) var index = {pendingIndex: e.pendingIndex } return index; } } ``` ![zh-cn_image_0000001163547244](figures/zh-cn_image_0000001163547244.gif) ## 场景示例 在本场景中,开发者可以在界面上点击选择并实时显示选择结果,点击下一步按钮后可动态修改页面的字体颜色和字体大小。 用Stepper组件实现分步,再创建[Toggle](../reference/arkui-js/js-components-basic-toggle.md)组件实现选择显示功能,再使用[Select](../reference/arkui-js/js-components-basic-select.md)组件实现改变选中值动态修改字体颜色或大小。 ```
Select error types: {{error}}
Toggle
text-color
font-size
``` ``` /* xxx.css */ .container { flex-direction: column; align-items: center; justify-content: center; background-color:#F1F3F5; } .dvd { stroke-width: 8px; color: orangered; margin: 65px; } .tog{ margin-right: 20px; margin-top: 30px; } ``` ``` /* index.js */ import prompt from '@system.prompt'; import router from '@system.router'; let myset = new Set(); export default { data: { error: '', tcolor:'#FF4500', color_list:['#FF4500','#5F9EA0','#0000FF'], tsize: '12px', size_list: ['12px', '30px', '8px', '50px'], label1: { prevLabel: 'The text on the left of the starting step is invalid.', nextLabel: 'Toggle' }, label2: { prevLabel: 'toggle', nextLabel: 'END' }, togglelist1:['Program error', 'Software', 'System', 'Application'], }, multiTog(arg, e) { this.error = ' ' if (e.checked) { myset.add(arg) } else { myset.delete(arg) } for (let item of myset) { this.error += item + ' ' } }, settcolor(e) { this.tcolor = e.newValue }, settsize(e) { this.tsize = e.newValue } } ``` ![zh-cn_image_0000001163214740](figures/zh-cn_image_0000001163214740.gif)