先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新HarmonyOS鸿蒙全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上鸿蒙开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip204888 (备注鸿蒙)

正文

Grid(){ ForEach(this.momentItem.images, (imagePath: string,index:number) => { GridItem() { Image(imagePath) } }) } .columnsTemplate(this.calcColumnsTemplate()) .rowsTemplate(this.calcRowsTemplate()) .width(this.calcGridRow()) .height(this.calcGridColum()) .columnsGap(7) .rowsGap(7) .margin({top:5})

//计算列数 calcRowsTemplate(){ if(this.momentItem.images.length <= 3){ return ‘1fr’ }else if(this.momentItem.images.length > 3 && this.momentItem.images.length <= 6){ return ‘1fr 1fr’ }else { return ‘1fr 1fr 1fr’ } } //计算行数 calcColumnsTemplate(){ if(this.momentItem.images.length <= 1){ return ‘1fr’ }else if(this.momentItem.images.length == 2){ return ‘1fr 1fr’ }else { return ‘1fr 1fr 1fr’ } }

第5部分看似是横向布局,它其实是一个叠加布局,黑色弹窗和两侧内容的叠加。代码如下:

Stack({alignContent:Alignment.End}){ Flex({direction:FlexDirection.Row,justifyContent:FlexAlign.SpaceBetween,alignItems:ItemAlign.Center}){ Text(this.momentItem.date) .fontColor(‘rgb(185,185,185)’) .fontSize(13) Text(‘••’) .width(35) .height(18) .borderRadius(5) .fontSize(12) .fontWeight(900) .textAlign(TextAlign.Center) .fontColor(‘rgb(90,109,150)’) .backgroundColor(‘rgb(247,247,247)’)

} .padding({right:20}) .height(40)

Flex({direction:FlexDirection.Row,}){ Flex({direction:FlexDirection.Row}){ Flex({direction:FlexDirection.Row,justifyContent:FlexAlign.Center,alignItems:ItemAlign.Center}){ Image(KaTeX parse error: Expected 'EOF', got '}' at position 122: …tAlign.Center) }̲ .width(60) .he…r(‘app.media.commen’)) .width(18) .height(18) Text(‘评论’) .fontColor(Color.White) .fontSize(14) .textAlign(TextAlign.Center) } .width(60) .height(40) } .borderRadius(4) .width(120) .height(40) .position({x:0}) .backgroundColor(‘rgb(22,22,22)’)

} .margin({right:60}) .width(120) .height(40)

} .height(40)

这样做完之后,看下效果:

问题来了,评论和赞的弹窗不应该每一行都显示,它只能点击的时候显示一个并且带有动画效果,所以现在全部把它们隐藏,注意这里的隐藏不能使用Visibility.Hidden,而是设置位置和尺寸。因为只有宽度和x坐标的同时变化才能做到朋友圈那样的效果,假设弹窗显示时的x坐标是0,宽度120,那么动画开始之前x初始值应该是120,宽度为0才对,但是幽蓝君亲身实验宽度为0时是不行的,所以这里宽度初始值设置0.01,肉眼看不见就好。

说了一通,不知道大家能不能理解,看代码吧,当右侧的按钮点击时:

@State menuWidth:number = 0.001 //弹窗width初始值 @State menuX:number = 120 //弹窗x值初始值

animateTo({ duration: 300, onFinish:() => { this.momentItem.showC = !this.momentItem.showC } }, () => { if(!this.momentItem.showC){ //弹出 this.menuX = 0 this.menuWidth = 120 }else { //收起 this.menuX = 120 this.menuWidth = 0.001 } })

这样可以实现单个弹窗的弹出和收起,但是我们要控制整个页面只能出现一个弹窗,所以在上述点击事件中要同时把点击的序号index传给父组件,让父组件处理数据列表,除index外其他行的showC置为false。

问题又来了,我们之前说过,@state修饰的变量,嵌套数据的变化它是监测不到的,所以即便把数据修改了其他弹窗也不会隐藏。

所以子组件中数据对象使用@ObjectLink修饰,数据模型MomentClass也要使用@Observed修饰:

@Observed class MomentClass { public nickName: string; public content: string; public date: string; public showC: boolean; public images: string[];

constructor(nickName: string,content: string,date: string,showC: boolean,images:string[]) { this.nickName = nickName; this.content = content; this.date = date; this.showC = showC; this.images = images; } }

@ObjectLink @Watch(‘onCountUpdated2’) momentItem: MomentClass;

这样就完成了整个评论弹窗的控制。

接下来就是导航栏了,导航栏有一个显示和隐藏的切换,规律是当第一个listGroupItem滑动消失时导航栏显示,否则隐藏。List组件有一个onScrollIndex方法:

onScrollIndex((start,end)=>{ if(start == 0 && end == 1){ this.navHide = true } if(start == 1 && end == 1){ this.navHide = false } })

然后把navHide变量赋值给导航栏的hideTitleBar:

hideTitleBar(this.navHide)

这样导航栏就可以按照我们要求显示和隐藏了,至于隐藏时的导航栏图标大家可以自己添加一个,和导航栏反向显示就行了。

最后就是点击预览朋友圈图片,幽蓝君的做法是点击图片弹出一个List组件覆盖到屏幕上,看代码:

if (this.previewAlpha) { List({initialIndex:this.bigImageIndex}){ ForEach(this.bigImageList,(imagePath)=>{ ListItem(){ Image(imagePath) .width(‘100%’) .height(‘100%’) .objectFit(ImageFit.Auto) } })

} .edgeEffect(EdgeEffect.Spring) .listDirection(Axis.Horizontal) .width(‘100%’) .height(‘100%’) .backgroundColor(Color.Black) .onClick(()=>{ animateTo({ duration: 500 }, () => { // 动画闭包内控制Image组件的出现和消失 this.previewAlpha = !this.previewAlpha; }) }) //弹出动画 .transition({ type: TransitionType.Insert, translate: { x: 20, y: 20 },scale: { x: 0, y: 0 } }) //消失动画 .transition({ type: TransitionType.Delete, opacity: 0, scale: { x: 0, y: 0 } }) }

点击图片的时候设置previewAlpha:

animateTo({ duration: 500 }, () => { // 动画闭包内控制Image组件的出现和消失 this.previewAlpha = !this.previewAlpha; })

这样朋友圈的功能就基本完成了。

大家如需获取本次内容源码,请点击尾部链接,直接获取

最后,有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以有一份实用的鸿蒙(Harmony NEXT)资料用来跟着学习是非常有必要的。

这份鸿蒙(Harmony NEXT)资料包含了鸿蒙开发必掌握的核心知识要点,内容包含了(**ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony****多媒体技术、Napi组件、OpenHarmony内核、Harmony南向开发、鸿蒙项目实战等等)鸿蒙(Harmony NEXT)**技术知识点。

希望这一份鸿蒙学习资料能够给大家带来帮助,有需要的小伙伴自行领取,限时开源,先到先得~无套路领取!!

如果你是一名有经验的资深Android移动开发、Java开发、前端开发、对鸿蒙感兴趣以及转行人员,可以直接领取这份资料

获取这份完整版高清学习路线,请点击→纯血版全套鸿蒙HarmonyOS学习资料****

鸿蒙(Harmony NEXT)最新学习路线

HarmonOS基础技能

HarmonOS就业必备技能 HarmonOS多媒体技术

鸿蒙NaPi组件进阶

HarmonOS高级技能

初识HarmonOS内核实战就业级设备开发

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注鸿蒙)

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip204888 (备注鸿蒙) [外链图片转存中…(img-Zz8HqtyO-1713220758601)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

推荐阅读

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: