# 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设置边框、背景色。
```
```
```
/* 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)