精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

基于ArkUI的運動記錄Demo

系統 OpenHarmony
本文主要介紹的是搜索欄跳轉至搜索結果界面,以及前述文章介紹的組件的應用。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??

前言

在參加了"HarmonyOS ArkUI入門訓練營——健康生活實戰"后,了解并學習了聲明式UI開發框架及組件用法,本文是對筆者結營作品中作一個小分享。在筆者上篇及前篇文章中,已對本demo作了部分組件的介紹,本文將對剩余部分作介紹分享~

概述

本文主要介紹的是搜索欄跳轉至搜索結果界面,以及前述文章介紹的組件的應用。效果圖如下:

#打卡不停更#【木棉花】:基于ArkUI的運動記錄Demo-開源基礎軟件社區

正文

一、工程文件架構

#打卡不停更#【木棉花】:基于ArkUI的運動記錄Demo-開源基礎軟件社區

二、完善主界面及數據的傳遞

1、數據傳遞實現運動記錄的增刪改查

由于運動記錄的增刪改查是在彈窗組件的點擊事件里相應的,起初我是打算使用@Link來傳遞數據的,但是在自定義彈窗組件的builder里會對$修飾的變量報錯,于是我就改用全局變量了。為了響應變量的狀態變化,用@State裝飾。也許用數據庫會更方便些,后期再作優化吧!

var RDArray: Array<RecordData> = []
var RSports: Array<SportsData> = []

Record 彈窗下定義變量。

@State RecordDataArray: Array<RecordData> = RDArray
@State RecordSports: Array<SportsData> = RSports

在上上篇文章提到的彈窗組件中,定義點擊事件。“修改記錄”模式下,“刪除記錄”按鍵的“確定”響應代碼如下:

secondaryButton: {
value: '確定',
action: () => {
RDArray.splice(this.item_index, 1)
RSports.splice(this.item_index, 1)
this.controller.close()
}

主彈窗右上角的“確定”按鍵響應代碼如下:

if (this.mode == 0) {
RDArray.push({
'name': this.sportsItem.name,
'image': this.sportsItem.image,
'time': this.time,
'sum': this.sum
})
RSports.push(this.sportsItem)
}
else if (this.mode == 1) {
RDArray[this.item_index]=
{
'name': this.sportsItem.name,
'image': this.sportsItem.image,
'time': this.time,
'sum': this.sum
}
RSports.push(this.sportsItem)
}

2、完善主頁面

主頁面底部是有兩個頁簽的導航欄,第一個頁簽顯示目錄界面,該界面的頂部有一個搜索欄,與下方的目錄成縱向布局,第二個頁簽顯示記錄界面。記錄界面的組件與上篇文章提到的List組件用法無異,只是渲染的數據不同罷了,代碼相似所以本文就不介紹了。此外對于記錄界面,若無記錄則顯示“暫無記錄”,為了讓界面美觀些,筆者給背景添加了圖片。點擊“搜索”按鍵時會帶參跳轉至搜索結果的頁面’pages/search_result’,代碼如下:

@Entry
@Component
struct SportsCategoryList {
@State RDArray: Array<RecordData> = RDArray
@State RSports: Array<SportsData> = RSports
@State currentIndex: number = 0;
@State search_item: string = '運動名稱';
private sportsItem: SportsData[] = initializeOnStartup()

@Builder bottomBarBuilder(name: string, image_active: Resource, image_inactive: Resource, index: number) {
Column() {
Image(this.currentIndex === index ? image_active : image_inactive).width(32).aspectRatio(1).fillColor(this.currentIndex === index ? '#3ECF69' : '#bfbfbf')
Text(name).fontColor(this.currentIndex === index ? '#3ECF69' : '#bfbfbf').fontSize(18).margin({ bottom: 3 })
}.alignItems(HorizontalAlign.Center).width('100%')
}
build() {
Tabs({ barPosition: BarPosition.End }) {
TabContent() {
Column() {
Row() {
Image($r('app.media.search'))
.width(26)
.height(26)
.objectFit(ImageFit.Cover)
.margin({ left: 10 })

TextInput({ placeholder: '請輸入運動名稱' })
.width('60%')
.height(30)
.backgroundColor(Color.White)
.onChange((value: string) => {
this.search_item = value
})
Blank()
Button('搜索')
.backgroundColor('#3ECF69')
.borderRadius(30)
.fontSize(15)
.fontColor(Color.White)
.height(30)
.width('20%')
.margin({ left: 8, right: 3, top: 3, bottom: 3 })
.onClick(() => {
router.push({
url: 'pages/search_result',
params: {
sports: this.search_item
}
})
})
} //search
.borderColor('#3ECF69')
.borderWidth(2)
.borderRadius(50)
.backgroundColor(Color.White)
.width('90%')
.height(40)
.margin({ top: 5, bottom: 5, left: 5, right: 5 })
SportsCategory({ sportsItems: this.sportsItem ,RecordSports:$RSports,RecordDataArray:$RDArray})
}
.backgroundImage($r('app.media.background'))
.backgroundImageSize({ width: '100%', height: '100%' })
}.tabBar(this.bottomBarBuilder('主頁', $r('app.media.index'), $r('app.media.indexgray'), 0))
TabContent() {
Column() {
if (this.RDArray.length != 0) {
RecordGrid({RecordDataArray:$RDArray,RecordSports:$RSports})
}
else {
Text('暫無運動記錄').fontSize(19).width('100%').height(20).margin({ top: 12, left: 20 })
}
}
.width('100%')
.height('100%')
.backgroundImage($r('app.media.background2'))
.backgroundImageSize({ width: '100%', height: '100%' })

}.tabBar(this.bottomBarBuilder('記錄', $r('app.media.statistics'), $r('app.media.statisticsgray'), 1))
}
.onChange((index: number) => {
this.currentIndex = index;
})
}
}

三、搜索結果界面

1、接收頁面路由的傳參,并初始化工程內的運動項數據,便于遍歷查找。

import router from '@ohos.router';
import { initializeOnStartup } from '../model/SportsDataModels'
import { SportsData,RecordData } from '../model/SportsData'
import { SportsGrid,RDArray,RSports } from './SportsCategoryList'
@Entry
@Component
struct Search_result {
@State name:string = router.getParams()['sports']
private sportsItem: SportsData[] = initializeOnStartup()
private ResultDataArray: Array<SportsData> = []
...
}

由于有的運動項目名稱相同,但配速不同,因此在設置字符串匹配判斷時取字符串的子串來匹配。

aboutToAppear() {
let item;
for (item of this.sportsItem) {
if (item.name.length >= this.name.length) {
if (this.name == item.name.substring(0, this.name.length)) {
this.ResultDataArray.push(item);
}
}
else {
if (this.name == item.name) {
this.ResultDataArray.push(item);
}
}
}
}

將SportsCategoryList中的SportsGrid組件用export修飾,就能在搜索結果界面使用了,將搜索的結果用數組存放,接著傳參進SportsGrid進行列表渲染。

build() {
Column() {
PageTitle({ title: '搜索結果' })
Row() {
Image($r('app.media.search'))
.width(26)
.height(26)
.objectFit(ImageFit.Cover)
.margin({ left: 10 })
TextInput({placeholder:'請輸入運動名稱'})
.width('60%')
.height(30)
.backgroundColor(Color.White)
Blank()
Button('搜索')
.backgroundColor('#3ECF69')
.borderRadius(30)
.fontSize(15)
.fontColor(Color.White)
.height(30)
.width('20%')
.margin({ left: 8, right: 3, top: 3, bottom: 3 })
.onClick(() => {
router.push({
url: 'pages/search_result',
params: {
sports: this.sportsItem
}
})
})
} //search
.borderColor('#3ECF69')
.borderWidth(2)
.borderRadius(50)
.backgroundColor(Color.White)
.width('90%')
.height(40)
.margin(5)

Scroll() {
Column() {
if (this.ResultDataArray.length != 0) {
SportsGrid({ sportsItems: this.ResultDataArray })
}
else {
Text('沒有查到與此相關的結果').fontSize(19).width('100%').height(20).margin({ top: 12, left: 20 })
}
}
}
.scrollBar(BarState.Off)
}.height('100%')
.width('100%')
.backgroundImage($r('app.media.background'))
.backgroundImageSize({ width: '100%', height: '100%' })
}
}
@Component
struct PageTitle {
private title: string
build() {
Flex({ alignItems: ItemAlign.Start }) {
Image($r('app.media.Back'))
.width(21.8)
.height(19.6)
Text(this.title)
.fontSize(21.8)
.margin({ left: 17.4 })
}
.height(61)
.padding({ top: 15, bottom: 10, left: 28.3 })
.onClick(() => {
router.back()
})
}

結語

以上就是本次的小分享啦!

文章相關附件可以點擊下面的原文鏈接前往下載:

https://ost.51cto.com/resource/2339。

??想了解更多關于開源的內容,請訪問:??

??51CTO 開源基礎軟件社區??

??https://ost.51cto.com??。

責任編輯:jianghua 來源: 51CTO開源基礎軟件社區
相關推薦

2022-10-18 15:49:28

List組件Tabs組件

2022-10-17 14:39:12

自定義彈窗組件鴻蒙

2022-06-14 15:13:22

Echarts柱狀圖

2024-05-31 08:43:31

2021-12-27 15:10:55

鴻蒙HarmonyOS應用

2022-05-27 14:55:34

canvas畫布鴻蒙

2022-10-24 14:49:54

ArkUI心電圖組件

2022-11-02 16:06:54

ArkUIETS

2024-01-11 15:54:55

eTS語言TypeScript應用開發

2022-09-14 15:17:26

ArkUI鴻蒙

2022-07-26 14:40:42

ArkUIJS

2022-10-17 14:36:09

ArkUI虛擬搖桿組件

2022-08-05 19:27:22

通用API鴻蒙

2022-07-13 16:24:12

ArkUI(JS)打地鼠游戲

2022-09-21 14:51:21

ArkUI信件彈出

2021-12-01 15:40:23

鴻蒙HarmonyOS應用

2021-12-01 15:38:33

鴻蒙HarmonyOS應用

2015-05-26 15:20:57

創業邦

2021-12-10 15:02:47

鴻蒙HarmonyOS應用

2021-12-10 15:05:41

鴻蒙HarmonyOS應用
點贊
收藏

51CTO技術棧公眾號

国产精品少妇自拍| 性欧美videos另类喷潮| 日韩女同互慰一区二区| 成人在线播放网址| 伦理片一区二区三区| 蜜桃视频第一区免费观看| 欧美伦理91i| 永久免费成人代码| 51社区在线成人免费视频| 欧洲色大大久久| 99在线观看视频免费| 国产youjizz在线| 床上的激情91.| 国产精品爽爽爽| www.国产成人| 亚洲欧美日韩高清在线| 亚洲人av在线影院| 性猛交╳xxx乱大交| 国模一区二区| 欧美日韩午夜激情| 精品久久久无码人妻字幂| 国产鲁鲁视频在线观看免费| 国产a视频精品免费观看| 国产精品久久不能| 欧美亚韩一区二区三区| 综合亚洲视频| 中国人与牲禽动交精品| 大黑人交xxx极品hd| 亚洲超碰在线观看| 欧美妇女性影城| 另类小说第一页| www555久久| 亚洲少妇最新在线视频| 手机在线观看国产精品| 青青九九免费视频在线| 亚洲精品国产片| 污的网站在线观看| 国产精品入口麻豆九色| 久久99精品久久久久久青青日本 | 91探花福利精品国产自产在线 | 久久久久久一区二区| 高清欧美性猛交xxxx| 青青草原免费观看| 影音先锋成人在线电影| 日韩一区二区久久久| 黄色三级生活片| 经典一区二区| 亚洲小视频在线观看| 一区二区三区免费在线观看视频| 国产人妖ts一区二区| 全国精品免费看| 亚洲欧美激情一区二区| 正在播放91九色| 9色在线视频| 欧美极品少妇xxxxⅹ高跟鞋 | 黄色片免费在线| 久久亚洲欧美国产精品乐播 | 色综合久久久网| 国产免费黄色av| 伊伊综合在线| 欧洲一区二区av| 色呦色呦色精品| 国产亚洲精aa在线看| 欧美一二三四区在线| 韩国av中国字幕| 国产精品任我爽爆在线播放| 亚洲国产天堂久久综合网| 国产呦小j女精品视频| 亚洲宅男一区| 中文字幕亚洲欧美日韩高清| 精品丰满少妇一区二区三区| 日韩久久综合| 欧美国产精品va在线观看| 日本黄色片视频| 久久精品成人| 91亚洲va在线va天堂va国| 性欧美一区二区三区| 99精品视频一区| 日韩精品久久久| 高清全集视频免费在线| 亚洲福利国产精品| 日本成人黄色网| 99久热在线精品视频观看| 欧美zozo另类异族| 少妇大叫太粗太大爽一区二区| 嫩草一区二区三区| 久久精品国产精品| 色播视频在线播放| 视频一区在线播放| 51国偷自产一区二区三区| 婷婷在线免费观看| 中文一区二区完整视频在线观看 | 亚洲欧美久久| 成人在线一区二区| 蜜桃在线一区二区| 国产精品网站在线观看| 和岳每晚弄的高潮嗷嗷叫视频| 成人爱爱网址| 日韩一区二区三区四区五区六区| 天天插天天射天天干| 欧美韩国日本在线观看 | www.久久| 精品国产一区二区三区忘忧草| 中国美女乱淫免费看视频| 中文字幕亚洲精品乱码| 日本欧美国产在线| 亚洲黄色在线播放| 国产精品久久久久久福利一牛影视| 久久亚洲国产成人精品无码区| 伊人久久高清| 日韩av最新在线| 亚洲最大的黄色网址| 久久综合五月| 国产麻豆日韩| 麻豆av免费在线观看| 色偷偷成人一区二区三区91| 无码人妻久久一区二区三区蜜桃| 人人狠狠综合久久亚洲婷婷 | 亚洲国产精选| 亚洲网址你懂得| 久久草视频在线| 国产黄色精品视频| 中文字幕精品—区二区日日骚| 中文字幕资源网在线观看免费 | 91.成人天堂一区| 少妇按摩一区二区三区| 亚洲精品美女91| 成人动漫视频在线观看免费| 视频一区在线免费观看| 免费国产精品视频| 亚洲免费观看高清在线观看| 日日噜噜噜噜久久久精品毛片| 日韩欧美国产大片| 韩国精品久久久999| 国产99久一区二区三区a片| 91香蕉国产在线观看软件| 99在线免费视频观看| 精品麻豆剧传媒av国产九九九| 中文字幕亚洲欧美| 在线视频你懂得| 中文字幕乱码日本亚洲一区二区| 无码人妻h动漫| 岳的好大精品一区二区三区| 2019最新中文字幕| 亚洲色大成网站www| 黑人巨大精品欧美一区二区免费| 亚洲av成人片色在线观看高潮| 亚洲性感美女99在线| 国产私拍一区| 日韩av一卡| 亚洲免费影视第一页| 中文字幕在线看人| 国产清纯美女被跳蛋高潮一区二区久久w | 精品视频一区二区三区免费| 美女被到爽高潮视频| 日韩精品每日更新| 少妇免费毛片久久久久久久久 | 一本一本久久a久久| 免费成人av在线| 亚洲午夜精品一区二区 | 欧美一区二区久久久| 91 在线视频| 国产成人鲁色资源国产91色综| 成人免费观看在线| 性欧美xxxx免费岛国不卡电影| 欧洲成人在线视频| 黄色在线免费观看大全| 欧美日韩成人综合在线一区二区 | 午夜一区二区三区视频| 亚洲熟妇无码av| 蜜桃精品视频在线观看| 天天干天天色天天爽| 6080亚洲理论片在线观看| 韩国一区二区电影| 国产在线视频网站| 欧美一区二区三区电影| 日韩黄色a级片| 国产视频在线观看一区二区三区| 一道本在线免费视频| 欧美久色视频| 欧美主播一区二区三区美女 久久精品人| 欧美色片在线观看| 欧美夫妻性视频| 国产资源在线播放| 91精品国产综合久久婷婷香蕉 | 日韩乱码在线观看| 国产日韩欧美激情| 久久久男人的天堂| 日本伊人色综合网| 国产美女永久无遮挡| 国产一区三区在线播放| 91久久国产综合久久蜜月精品| 日韩伦理在线一区| 久久久91精品| 男人av在线| 日韩免费观看高清完整版在线观看| 在线免费黄色av| 亚洲综合一二三区| 又嫩又硬又黄又爽的视频| 成人爱爱电影网址| 极品粉嫩美女露脸啪啪| 国产精品毛片在线看| 国产日产欧美一区二区| 久久最新网址| 狠狠色综合网站久久久久久久| 色综合一区二区日本韩国亚洲 | 99国产成人精品| 日韩欧美一区二区在线| 劲爆欧美第一页| 国产精品久久久久久久久动漫| 亚洲制服丝袜在线播放| 国产精品影视网| 午夜两性免费视频| 99国产精品视频免费观看一公开| 日本福利视频导航| 国产一区二区电影在线观看| 精品91免费| 中文字幕久久精品一区二区| 91精品国产综合久久男男| 二吊插入一穴一区二区| 国语自产精品视频在线看抢先版图片 | 91一区二区三区在线播放| 国产精品久久久久久9999| 日韩av一区二区在线影视| 日韩欧美国产免费| 亚洲欧洲一区二区天堂久久| 真人做人试看60分钟免费| 91视频一区| 亚洲国产精品日韩| 欧美丝袜丝交足nylons172| 欧美大香线蕉线伊人久久| 粉嫩的18在线观看极品精品| 99电影在线观看| 亚洲三级av| 官网99热精品| 给我免费播放日韩视频| 成人18视频| 99久久婷婷国产综合精品青牛牛| 亚洲最大福利视频网| 免费观看性欧美大片无片| 成人免费视频网| 高清精品久久| 91国产丝袜在线放| 日韩精品一区二区三区中文在线| 91精品视频免费看| 国语精品视频| 99国产精品久久久久老师| 日本高清久久| 国产a一区二区| 里番精品3d一二三区| 美女亚洲精品| 夜夜春成人影院| 日韩免费一区二区三区| 日韩久久久久| 久久www视频| 好看不卡的中文字幕| 成人网站免费观看入口| 中文精品视频| 欧美精品无码一区二区三区| 男女视频一区二区| 蜜桃福利午夜精品一区| 丁香激情综合五月| 国产精品一区二区入口九绯色| 久久这里只有精品视频网| 五月天精品视频| 国产精品丝袜一区| 免费麻豆国产一区二区三区四区| 亚洲成人福利片| 欧美brazzers| 7777精品伊人久久久大香线蕉经典版下载| 99在线小视频| 亚洲精品久久在线| 91最新在线| 欧美国产在线视频| 周于希免费高清在线观看 | 国产欧美自拍一区| 色噜噜狠狠一区二区三区| 五月久久久综合一区二区小说| 男女激情免费视频| 日精品一区二区| 特种兵之深入敌后| 久久久久久亚洲综合| 波兰性xxxxx极品hd| 亚洲超丰满肉感bbw| 国产精品传媒在线观看| 欧美一卡二卡三卡| 九色蝌蚪在线| 欧美激情精品久久久久久变态| 日韩不卡免费高清视频| 亚洲自拍av在线| 国产一区二区三区四区五区| 国产 欧美 日韩 一区| 日韩一区精品视频| 少妇精品无码一区二区| 国产日韩av一区| 国产无遮挡aaa片爽爽| 欧美日韩免费一区二区三区| 手机看片一区二区| 欧美成人国产va精品日本一级| 在线天堂资源www在线污| 91av免费看| 成人黄色小视频| 人妻熟妇乱又伦精品视频| 国内精品久久久久影院色| 无码人妻精品一区二区中文| 亚洲一区二区三区影院| 一级黄色免费看| 亚洲欧美日韩网| sm捆绑调教国产免费网站在线观看| 国产日韩精品一区二区| 亚洲精品白浆高清| 久久久久99精品成人片| 韩日精品视频一区| 日韩中文字幕有码| 天天影视色香欲综合网老头| 精品人妻一区二区三区含羞草| 伊人伊成久久人综合网小说| 人人草在线视频| 国产欧美日韩亚洲| 国产精品v一区二区三区 | 99久久精品情趣| 综合五月激情网| 欧美日韩亚洲综合在线| 免费黄网站在线观看| 91精品国产亚洲| 都市激情久久| 精品一二三四五区| 岛国一区二区在线观看| 欧美爱爱小视频| 欧美精品日韩精品| www在线播放| 国产精品日韩一区| 精品日韩欧美一区| 日韩有码免费视频| 国产三级久久久| 波多野结衣视频在线看| 亚洲性69xxxbbb| 欧美日韩精品一区二区三区视频| 日本一区二区三不卡| 视频一区视频二区在线观看| 三上悠亚影音先锋| 91精品1区2区| 成人精品一区二区三区校园激情| 日韩美女毛茸茸| 精品不卡一区| 日韩av卡一卡二| 亚洲日本在线视频观看| 国产免费久久久| 色综合久久悠悠| 丁香婷婷成人| 欧美黄色免费影院| 久久久精品2019中文字幕之3| 国产一级片av| 色综合影院在线| 精品国产亚洲一区二区三区在线 | 操喷在线视频| 久久大片网站| 日韩中文字幕亚洲一区二区va在线 | 欧美大胆a视频| 136国产福利精品导航网址应用| 国产爆乳无码一区二区麻豆| caoporn国产精品| 中文字幕69页| 中文字幕欧美日韩在线| 国产情侣一区在线| 青青草国产免费| 国产日韩精品一区| 国产精品久久久久久久成人午夜| 欧美超级免费视 在线| 国产一区丝袜| 毛葺葺老太做受视频| 最近日韩中文字幕| 人妻妺妺窝人体色www聚色窝| 热久久99这里有精品| 日本欧美肥老太交大片| 国产成人精品一区二区在线小狼 | 国产精品免费看片| av中文字幕播放| 欧美亚洲免费电影| 99久久久久国产精品| www.四虎精品| 欧美在线高清视频| 色a资源在线| 日本一区二区三区www| 国产成人av福利| 国产一级淫片a视频免费观看| 久久综合伊人77777尤物| 日韩伦理一区二区三区| 午夜宅男在线视频| 精品久久久久国产| 国产在线激情视频| 欧美日韩亚洲在线| 国产馆精品极品| 瑟瑟视频在线免费观看| 久久久综合免费视频| 欧美高清视频在线观看mv| 欧产日产国产精品98| 欧美美女一区二区在线观看| 美女高潮视频在线看| 无码人妻aⅴ一区二区三区日本|