0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于ETS开发范式制作Loading组件

OpenHarmony技术社区 来源:HarmonyOS技术社区 作者:HarmonyOS技术社区 2022-04-12 08:56 次阅读

最近刚接触基于 OpenHarmony 开源框架的应用开发,特别是基于 JS/ETS 开发范式。

其中基于 JS 的应用开发,与 vue 语法和思想高度相似,数据模型仅仅是普通的 JavaScript 对象。而当你修改它们时,视图会进行更新。这使得状态管理非常简单直接式。可以类比学习。

今天就 ETS 规范,写一个 Loading 的组件,熟悉 ETS 下的一些基础组件的应用和联动。

参考资料

OpenHarmony API
https://docs.openharmony.cn/pages/000701010201/
OpenHarmony / docs:
https://gitee.com/openharmony/docs/blob/master/zh-cn/application-dev/reference/arkui-ts/Readme-CN.md

UI开发模式

如下图:

9c3bd28e-b9c4-11ec-aa7f-dac502259ad0.png

实现

①新建项目

如下图:

9c5a6c30-b9c4-11ec-aa7f-dac502259ad0.png

语言选择 eTS,API Version 选择 8,不然部分组件不支持。

②页面布局

如下:
  • 用到的容器组件有:Column,Row

  • 用到的其他组件有:Image,Text,Slider

Column(){//沿垂直方向布局的容器
Row(){//沿水平方向布局容器。
Text()//文本,用于呈现一段信息
Image()
}
Row(){
Text()
Image()//图片组件,用来渲染展示图片。
}
Row(){
Text()
Silder()//滑动条组件,用来快速调节设置值,如音量、亮度等。
}
Row(){
Text()
Silder()
}
}
③根据 Silder 和 Image 的参数设置要求赋初始值

如下图:

9c6c6a84-b9c4-11ec-aa7f-dac502259ad0.png

@StateinSetValue:number=10
@StateoutVerticalSetValue:number=40
@StateinVerticalSetValue:number=40

@Stateprivatedegree:number=0
@Stateprivatespeed:number=5
@Stateprivatetimer:number=0
@StateprivateimageSize:number=0

④设置关联

将 Slider 进度值赋给 Image rotate 属性的坐标值,在页面加载的生命周期 onPageShow 中反复这一过程,最后记得把清楚定时器以免内存泄漏。

Image($r('app.media.load'))
.rotate({x:0,y:0,z:1,angle:this.degree}).objectFit(ImageFit.Contain)
.scale({x:this.imageSize,y:this.imageSize})

speedChange(){
this.timer=setInterval(()=>{
this.degree+=this.speed;
},20)
}
onPageShow(){
this.speedChange()
}
onPageHide(){
this.timer=null;
}

⑤用 @Builder() 装饰器封装相同的功能,减少冗余代码

代码如下:

//声明
@Builder
TextInfo(text:string){
Column(){
Text(text)
.fontSize(29)
.fontColor("#708090")
.width('90%')
.margin({top:20,left:25})
}
}
//调用
this.TextInfo('Changespeed'

效果图如下:

9c8fa134-b9c4-11ec-aa7f-dac502259ad0.png

总结

此例就基于 ETS 组件的基本使用和关联,以及装饰器 @Builer 的简单使用展开说明,旨在熟悉 ETS 规范和对组件的初体验。
思考:如果业务比较复杂,可以根据实际的场景和数据的情况抽成更小粒度的组件,以便更方便的组合,提升效率。

原文标题:在OpenHarmony上写一个Loading组件

文章出处:【微信公众号:HarmonyOS技术社区】欢迎添加关注!文章转载请注明出处。

审核编辑:汤梓红
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 开源
    +关注

    关注

    3

    文章

    3213

    浏览量

    42299
  • 组件
    +关注

    关注

    1

    文章

    503

    浏览量

    17782
  • OpenHarmony
    +关注

    关注

    25

    文章

    3633

    浏览量

    16050

原文标题:在OpenHarmony上写一个Loading组件

文章出处:【微信号:gh_834c4b3d87fe,微信公众号:OpenHarmony技术社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    基于eTS的HamronyOS应用开发

    随着HarmonyOS 3.0 Beta版的发布,API Version 8新增了大批JS/eTS API接口,相信很多开发者已经迫不及待想体验基于eTS的HamronyOS应用开发
    的头像 发表于 07-15 09:20 1943次阅读
    基于<b class='flag-5'>eTS</b>的HamronyOS应用<b class='flag-5'>开发</b>

    基于ArkUI eTS开发的坚果笑话(NutJoke)

      都说笑一笑十年少,确实,在生活中,我们也是很久没有笑了,那么今天,我就做一个鸿蒙eTS版的坚果笑话App, 实现的功能: 获取接口数据 笑话列表 笑话详情页 你能学到的有: 网络请求 可滚动组件
    的头像 发表于 08-19 09:59 1277次阅读

    课程预告丨12月15日官方直播带你领略ArkUI的声明式开发范式之美

    方舟开发框架(ArkUI)的声明式开发范式有什么优势?Java/JS/eTS(extended TypeScript)三种语言,用哪种语言更好?12月15日 19:00-20:30,H
    发表于 12-10 17:52

    HarmonyOS应用开发-eTS-Navigator组件练习

    说明:路由容器组件,提供路由跳转能力。接口:Navigator(value?: {target: string, type?: NavigationType})接口参数:属性:案例:创建新的ets
    发表于 12-21 09:36

    100行代码实现HarmonyOS“画图”应用,eTS开发走起!

    式UI框架——方舟开发框架(ArkUI)。ArkUI框架引入了基于TS扩展的声明式开发范式,让开发变得更加简洁、高效! 已经有很多开发者在
    发表于 03-30 14:28

    基于openHarmong ETS写一个Loading组件

    修改它们时,视图会进行更新。这使得状态管理非常简单直接式。可以类比学习。今天就ETS规范,写一个Loading组件,熟悉ETS下的一些基础组件
    发表于 03-31 14:37

    94个JS/eTS开源组件首发上新,肯定有你要用的一款!

    /eTS开发队伍中,我们也收到不少开发者对JS/eTS组件的需求,比如: 在广大组件贡献者
    发表于 05-09 14:51

    想学习eTS开发?教你开发一款IQ-EQ测试应用

    的独立创建、开发和复用。本次IQ- EQ测试应用,通过对容器组件的组合使用,实现了多个页面的UI布局。比如,EQ测试题目页(对应ets/default/pages/eqTest.ets
    发表于 06-23 12:01

    #深入浅出学习eTs#(五)eTs语言初识

    本项目Gitee仓地址:深入浅出eTs学习: 带大家深入浅出学习eTs (gitee.com)一、eTs介绍概述基于TS扩展的声明式开发范式
    发表于 12-29 10:02

    HarmonyOS/OpenHarmony应用开发-ArkTS的声明式开发范式

    轨迹。状态与数据管理状态数据管理作为基于ArkTS的声明式开发范式的特色,通过功能不同的装饰器给开发者提供了清晰的页面更新渲染流程和管道。状态管理包括UI组件状态和应用程序状态,两者协
    发表于 01-17 15:09

    HarmonyOS/OpenHarmony应用开发-类Web开发范式

    兼容JS的类Web开发范式的方舟开发框架,采用经典的HML、CSS、JavaScript三段式开发方式。使用HML标签文件进行布局搭建,使用CSS文件进行样式描述,使用JavaScri
    发表于 01-18 19:15

    HarmonyOS/OpenHarmony应用开发-声明式开发范式组件汇总

    组件是构建页面的核心,每个组件通过对数据和方法的简单封装,实现独立的可视、可交互功能单元。组件之间相互独立,随取随用,也可以在需求相同的地方重复使用。声明式开发
    发表于 01-19 11:14

    方舟开发框架新增开源组件及其使用方法介绍

    /eTS开发队伍中,我们也收到不少开发者对JS/eTS组件的需求。 在广大组件贡献者的共同努力
    的头像 发表于 05-07 17:43 2563次阅读
    方舟<b class='flag-5'>开发</b>框架新增开源<b class='flag-5'>组件</b>及其使用方法介绍

    OpenHarmony应用开发ETS开发方式Image组件

    今天带大家了解ETS开发方式中的Image组件
    的头像 发表于 07-03 12:06 3415次阅读
    OpenHarmony应用<b class='flag-5'>开发</b>之<b class='flag-5'>ETS</b><b class='flag-5'>开发</b>方式Image<b class='flag-5'>组件</b>

    鸿蒙开发学习:【ets_frontend组件

    ets_frontend组件采用命令行交互方式,支持将JavaScript代码转换为方舟字节码文件,使其能够在方舟运行时上运行。支持Windows/Linux/MacOS平台。方舟前端工具在linux平台上可通过全量编译或指定编译前端工具链获取。
    的头像 发表于 03-10 19:58 290次阅读
    鸿蒙<b class='flag-5'>开发</b>学习:【<b class='flag-5'>ets</b>_frontend<b class='flag-5'>组件</b>】