列表的編輯模式用途十分廣泛,常見于待辦事項管理、文件管理、備忘錄的記錄管理等應用場景。
在列表的編輯模式下,新增和刪除列表項是最基礎的功能,其核心是對列表項對應的數(shù)據(jù)集合進行數(shù)據(jù)添加和刪除。
下面以待辦事項管理為例,介紹如何快速實現(xiàn)新增和刪除列表項功能。
環(huán)境要求
本例基于以下環(huán)境開發(fā),開發(fā)者也可以基于其他適配的版本進行開發(fā):
IDE:DevEco Studio 3.1 Release
SDK:Ohos_sdk_public 3.2.12.5(API Version 9 Release)
新增列表項
當用戶點擊添加按鈕時,將彈出列表項選擇界面,用戶點擊確定后,列表中新增對應項目。
新增待辦
開發(fā)步驟
定義列表項數(shù)據(jù)結(jié)構(gòu)和初始化列表數(shù)據(jù),構(gòu)建列表整體布局和列表項。
以待辦事項管理為例,首先定義待辦事項的數(shù)據(jù)結(jié)構(gòu):
importutilfrom'@ohos.util'; exportclassToDo{ key:string=util.generateRandomUUID(true); name:string; constructor(name:string){ this.name=name; } }然后,初始化待辦事項列表和可選事項列表:
@StatetoDoData:ToDo[]=[]; privateavailableThings:string[]=['讀書','運動','旅游','聽音樂','看電影','唱歌'];構(gòu)建 UI 界面,初始界面包含“待辦”和新增按鈕“+”:
Text('待辦') .fontSize(36) .margin({left:40}) Blank() Text('+') .fontWeight(FontWeight.Lighter) .fontSize(40) .margin({right:30})構(gòu)建列表布局并通過 ForEach 循環(huán)渲染列表項:
List({space:10}){ ForEach(this.toDoData,(toDoItem)=>{ ListItem(){ ... } },toDoItem=>toDoItem.key) }為新增按鈕綁定點擊事件,并在事件中通過 TextPickerDialog.show 添加新增列表項的邏輯:
Text('+') .onClick(()=>{ TextPickerDialog.show({ range:this.availableThings,//將可選事項列表配置到選擇對話框中 onAccept:(value:TextPickerResult)=>{ this.toDoData.push(newToDo(this.availableThings[value.index]));//用戶點擊確認,將選擇的數(shù)據(jù)添加到待辦列表toDoData中 }, }) })
刪除列表項
當用戶長按列表項進入刪除模式時,提供用戶刪除列表項選擇的交互界面,用戶勾選完成后點擊刪除按鈕,列表中刪除對應的項目。
長按刪除待辦事項
開發(fā)步驟
列表的刪除功能一般進入編輯模式后才可使用,所以需要提供編輯模式的入口。
以待辦列表為例,通過 LongPressGesture() 監(jiān)聽列表項的長按事件,當用戶長按列表項時,進入編輯模式。
//ToDoListItem.ets Flex({justifyContent:FlexAlign.SpaceBetween,alignItems:ItemAlign.Center}){ ... } .gesture( GestureGroup(GestureMode.Exclusive, LongPressGesture()//監(jiān)聽長按事件 .onAction(()=>{ if(!this.isEditMode){ this.isEditMode=true;//進入編輯模式 this.selectedItems.push(this.toDoItem);//記錄長按時選中的列表項 } }) ) )
需要響應用戶的選擇交互,記錄要刪除的列表項數(shù)據(jù)。
在待辦列表中,通過勾選框的勾選或取消勾選,響應用戶勾選列表項變化,記錄所有選擇的列表項。
//ToDoListItem.ets if(this.isEditMode){ Checkbox() .onChange((isSelected)=>{ if(isSelected){ this.selectedItems.push(this.toDoItem)//勾選時,記錄選中的列表項 }else{ letindex=this.selectedItems.indexOf(this.toDoItem) if(index!==-1){ this.selectedItems.splice(index,1)//取消勾選時,則將此項從selectedItems中刪除 } } }) ... }需要響應用戶點擊刪除按鈕事件,刪除列表中對應的選項。
//ToDoList.ets Button('刪除') .onClick(()=>{ //刪除選中的列表項對應的toDoData數(shù)據(jù) letleftData=this.toDoData.filter((item)=>{ returnthis.selectedItems.find((selectedItem)=>selectedItem!==item); }) this.toDoData=leftData; this.isEditMode=false; }) ...
完整示例代碼
新增和刪除列表項的實現(xiàn)共涉及三個文件,各文件完整代碼如下:
待辦事項數(shù)據(jù)結(jié)構(gòu)代碼(ToDo.ets):
//ToDo.ets importutilfrom'@ohos.util'; exportclassToDo{ key:string=util.generateRandomUUID(true) name:string; constructor(name:string){ this.name=name; } }待辦事項列表代碼(ToDoList.ets):
//ToDoList.ets import{ToDo}from'../model/ToDo'; import{ToDoListItem}from'./ToDoListItem'; @Entry @Component structToDoList{ @StatetoDoData:ToDo[]=[] @Watch('onEditModeChange')@StateisEditMode:boolean=false @StateselectedItems:ToDo[]=[] privateavailableThings:string[]=["讀書","運動","旅游",'聽音樂','看電影','唱歌'] saveData(value:string){ this.toDoData.push(newToDo(value)) } onEditModeChange(){ if(!this.isEditMode){ this.selectedItems=[] } } build(){ Column(){ Row(){ if(this.isEditMode){ Text('X') .fontSize(20) .onClick(()=>{ this.isEditMode=false; }) .margin({left:20,right:20}) Text('已選擇'+this.selectedItems.length+'項') .fontSize(24) }else{ Text('待辦') .fontSize(36) .margin({left:40}) Blank() Text('+') .fontWeight(FontWeight.Lighter) .fontSize(40) .margin({right:30}) .onClick(()=>{ TextPickerDialog.show({ range:this.availableThings, onAccept:(value:TextPickerResult)=>{ this.toDoData.push(newToDo(this.availableThings[value.index])) console.info('tododata:'+JSON.stringify(this.toDoData)) }, }) }) } } .height('12%') .width('100%') List({initialIndex:0,space:10}){ ForEach(this.toDoData,toDoItem=>{ ListItem(){ ToDoListItem({ isEditMode:$isEditMode, toDoItem:toDoItem, selectedItems:$selectedItems }) }.padding({left:24,right:24,bottom:12}) },toDoItem=>toDoItem.key) } .height('73%') .listDirection(Axis.Vertical) .edgeEffect(EdgeEffect.Spring) if(this.isEditMode){ Row(){ Button('刪除') .width('80%') .onClick(()=>{ letleftData=this.toDoData.filter((item)=>{ returnthis.selectedItems.find((selectedItem)=>selectedItem!=item) }) console.log('leftData:'+leftData); this.isEditMode=false; this.toDoData=leftData; }) .backgroundColor('#ffd75d5d') } .height('15%') } } .backgroundColor('#fff1f3f5') .width('100%') .height('100%') } }待辦事項代碼(ToDoListItem.ets):
//ToDoListItem.ets import{ToDo}from'../model/ToDo'; @Component exportstructToDoListItem{ @LinkisEditMode:boolean @LinkselectedItems:ToDo[] privatetoDoItem:ToDo; hasBeenSelected():boolean{ returnthis.selectedItems.indexOf(this.toDoItem)!=-1 } build(){ Flex({justifyContent:FlexAlign.SpaceBetween,alignItems:ItemAlign.Center}){ Row({space:4}){ Circle() .width(24) .height(24) .fill(Color.White) .borderWidth(3) .borderRadius(30) .borderColor('#ffdcdfdf') .margin({right:10}) Text(`${this.toDoItem.name}`) .maxLines(1) .fontSize(24) .textOverflow({overflow:TextOverflow.Ellipsis}) } .padding({left:12}) if(this.isEditMode){ Checkbox() .select(this.hasBeenSelected()?true:false) .onChange((isSelected)=>{ if(isSelected){ this.selectedItems.push(this.toDoItem) }else{ letindex=this.selectedItems.indexOf(this.toDoItem) if(index!=-1){ this.selectedItems.splice(index,1) } } }) .width(24) .height(24) } } .width('100%') .height(80) .padding({ left:16, right:12, top:4, bottom:4 }) .borderRadius(24) .linearGradient({ direction:GradientDirection.Right, colors:this.hasBeenSelected()?[[0xffcdae,0.0],[0xFfece2,1.0]]:[[0xffffff,0.0],[0xffffff,1.0]] }) .gesture( GestureGroup(GestureMode.Exclusive, LongPressGesture() .onAction(()=>{ if(!this.isEditMode){ this.isEditMode=true this.selectedItems.push(this.toDoItem) } }) ) ) } }
審核編輯:湯梓紅
-
IDE
+關注
關注
0文章
338瀏覽量
46794 -
文件管理
+關注
關注
0文章
13瀏覽量
8907 -
SDK
+關注
關注
3文章
1040瀏覽量
46052 -
OpenHarmony
+關注
關注
25文章
3730瀏覽量
16424
原文標題:OpenHarmony上實現(xiàn)“待辦事項”功能
文章出處:【微信號:gh_834c4b3d87fe,微信公眾號:OpenHarmony技術社區(qū)】歡迎添加關注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論