data:image/s3,"s3://crabby-images/b7fe9/b7fe944d2de3a4ca250df6799142fe53bd0be0b0" alt=""
data:image/s3,"s3://crabby-images/1d84b/1d84b32cfe47744094a4a92ba6c9e95d6923e012" alt=""
data:image/s3,"s3://crabby-images/f8153/f81532f033b469c194a30dd21543262cd243c74e" alt=""
data:image/s3,"s3://crabby-images/a64fb/a64fb57db19f30346221d10aaeeb99111290d820" alt=""
data:image/s3,"s3://crabby-images/331c0/331c02739ee4b67e6ba9fe185761529e9cbb40da" alt=""
data:image/s3,"s3://crabby-images/626c2/626c2cb38411e61e14ad80b911becbe690e67634" alt=""
data:image/s3,"s3://crabby-images/1bbad/1bbad858d1cd21aaabf8e77cffd892bb5e64bf57" alt=""
Image图片组件
data:image/s3,"s3://crabby-images/8b35b/8b35b91e97267939d0dd25ee587ab1fbec940bdc" alt=""
data:image/s3,"s3://crabby-images/6ad4b/6ad4badf9d77ee896e077b687da2728ced04c195" alt=""
data:image/s3,"s3://crabby-images/7be63/7be6324def7177e5304d4336c5ca46e302a6a8e6" alt=""
Text组件
data:image/s3,"s3://crabby-images/ac497/ac497cdb86d22011841b3d44260c225158677d7b" alt=""
如在两个限定目录里面定义完后,也要在 base牡蛎下去定义一下,不然会报错
TextInput
data:image/s3,"s3://crabby-images/c3bf7/c3bf7ef9a28cc232491c6f8be6170fb67ca67f71" alt=""
Button
data:image/s3,"s3://crabby-images/90df6/90df62afc8d9070387a182c4378635bd36687eab" alt=""
Slider
data:image/s3,"s3://crabby-images/5a976/5a976560db5a5de2673575b348e6801653ea38aa" alt=""
案例
ts
@State imageWidth:number=30
//构建 → 界面
build() {
Column(){
Image($r('app.media.startIcon'))
.width(this.imageWidth)
TextInput({placeholder:this.imageWidth.toFixed(0)})
.width(240)
.height(40)
.onChange(value=>{
this.imageWidth=parseInt(value)
})
Row(){
Button('增加')
.onClick(()=>{
this.imageWidth+=10
})
Button('缩小')
.onClick(()=>{
this.imageWidth-=10
})
}
Slider({
min:0,
max:100,
step:10,
value:this.imageWidth,
style:SliderStyle.InSet,//在内还是在外
direction:Axis.Horizontal,//进度条水平还是 垂直
reverse:false//是否反向滑动
}).showTips(true)//是否显示百分比
.onChange(value=>{
this.imageWidth=value
})
}.width('100%').height('100%').padding(20).backgroundColor(Color.Pink)
.padding(20)
Column和Row
data:image/s3,"s3://crabby-images/b4580/b458026570ce50c2219aa031bf9c7adf8b4a26d7" alt=""
justifyContent
data:image/s3,"s3://crabby-images/ce613/ce613c54db9afe8b7b5a406b2c6e431a5fe74956" alt=""
data:image/s3,"s3://crabby-images/8e9b5/8e9b5e9279b49437e45db80a0f7b0db5acec64be" alt=""
Divider分割线
data:image/s3,"s3://crabby-images/86566/865669c2b4419f270ca0beca8c961450aa0fa99d" alt=""
渲染控制
data:image/s3,"s3://crabby-images/40a5d/40a5dd328bfc9397ce125cc814bf24eff0a0767e" alt=""
案例
ts
class Item{
name:string
image:ResourceStr
price:number
constructor(name:string,image:ResourceStr,price:number) {
this.name=name
this.image=image
this.price=price
}
}
@Entry
@Component
struct demo {
@State message:number=1;
@State color:string='#CCCC'
@State count:number=8888
@State imageWidth:number=30
private items: Array<Item>=[
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999)
]
//构建 → 界面
build() {
Column(){
Text('商品列表').fontSize(24).fontWeight(FontWeight.Bold).width('100%')
ForEach(this.items,
(item:Item)=>{
Row(){
Image(item.image).width(60)
Column(){
Text(item.name).fontSize(16)
Text(item.price.toFixed(0)).fontColor(Color.Red).fontSize(13)
}.alignItems(HorizontalAlign.Start)
}.width('100%').height(80)
.justifyContent(FlexAlign.SpaceBetween)
.padding({left:15,right:15})
.margin({top:30})
.backgroundColor(Color.White)
.borderRadius(10)
})
}.width('100%').height('100%').padding(20).backgroundColor(Color.Pink)
.padding(20)
}
}
data:image/s3,"s3://crabby-images/6d9ef/6d9eff6f3503f263cfc3a8c7626d445fa1974bcd" alt=""
list组件
data:image/s3,"s3://crabby-images/7ca3a/7ca3a0314d6403a9b6944a87cb8eff9e1cfdc576" alt=""
案例
ts
class Item{
name:string
image:ResourceStr
price:number
constructor(name:string,image:ResourceStr,price:number) {
this.name=name
this.image=image
this.price=price
}
}
@Entry
@Component
struct demo {
@State message:number=1;
@State color:string='#CCCC'
@State count:number=8888
@State imageWidth:number=30
private items: Array<Item>=[
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999),
new Item('华为60',$r('app.media.app_icon'),6999)
]
//构建 → 界面
build() {
Column(){
Text('商品列表').fontSize(24).fontWeight(FontWeight.Bold).width('100%')
.margin({bottom:30})
List({space:20}){
ForEach(this.items,
(item:Item)=>{
ListItem(){
Row(){
Image(item.image).width(60)
Column(){
Text(item.name).fontSize(16)
Text(item.price.toFixed(0)).fontColor(Color.Red).fontSize(13)
}.alignItems(HorizontalAlign.Start)
}.width('100%').height(100)
.justifyContent(FlexAlign.SpaceBetween)
.padding({left:15,right:15})
.backgroundColor(Color.White)
.borderRadius(10)
}
})
}.layoutWeight(1)
}.width('100%').height('100%').padding(20).backgroundColor(Color.Pink)
.padding(20)
}
}
自定义组件
data:image/s3,"s3://crabby-images/f39cc/f39cc6f197c11f44aefd2571f9c1d19f36f44dc5" alt=""
ts
//全局自定义构建函数
@Builder function ItemCard(item:Item){
Row(){
Image(item.image).width(60)
Column(){
Text(item.name).fontSize(16)
Text(item.price.toFixed(0)).fontColor(Color.Red).fontSize(13)
}.alignItems(HorizontalAlign.Start)
}.width('100%').height(100)
.justifyContent(FlexAlign.SpaceBetween)
.padding({left:15,right:15})
.backgroundColor(Color.White)
.borderRadius(10)
}
使用:
data:image/s3,"s3://crabby-images/850c5/850c50e9a38a39103f033c8d6eec98c4b0eeaa28" alt=""
ts
//全局公共样式函数
@Styles function StylesQuan(){
.width('100%')
.height('100%')
.padding(20)
.backgroundColor(Color.Pink)
.padding(20)
}
使用:
data:image/s3,"s3://crabby-images/bb2a4/bb2a4f7df588bf1c06b654161f61b7163741130e" alt=""
注意:只能抽取公共的,例如text,image这种有特有属性的组件就用不了
需要**@Extend()**继承该组件才可以(继承模式只能写在全局里)
data:image/s3,"s3://crabby-images/95255/95255fa7de937562704fcc0c12b4d1a012167095" alt=""
data:image/s3,"s3://crabby-images/3257d/3257d1a835239ae64685a0c6ac4b58127033de68" alt=""
data:image/s3,"s3://crabby-images/d8f13/d8f13b79a84e1f0c49d2a04859f19211ab58970c" alt=""
状态管理
@state
data:image/s3,"s3://crabby-images/9c699/9c699e3b57e33e2bef42e1a92cffa45207ac078f" alt=""
@prop和Link
data:image/s3,"s3://crabby-images/787a9/787a9b4b862645fd98a21f175842668753b7f9a1" alt=""
@Provide和@Consume
@objectLink和@Observed
嵌套对象
data:image/s3,"s3://crabby-images/a2923/a2923c00f5a7662a2e1d0c875c8c1810c64b1fc4" alt=""
数组元素
data:image/s3,"s3://crabby-images/54668/54668e79033fe5cd2b246549ed08ba3455ca2e5a" alt=""
页面路由
data:image/s3,"s3://crabby-images/26054/26054b726f1830a0fa7ebc7073e6eb06208bfa9f" alt=""
data:image/s3,"s3://crabby-images/89cce/89cce79f781b29341bef083d64e9b087aec4dcce" alt=""
data:image/s3,"s3://crabby-images/8afc5/8afc5cfb518efc770a7a5b056137dddda712b4b2" alt=""
data:image/s3,"s3://crabby-images/c6b14/c6b144462460b2872650189be83a44747efe5059" alt=""
页面动画 有点薄弱
data:image/s3,"s3://crabby-images/b23b0/b23b0c33a86cc938cd4764c9454b9703110e41a9" alt=""
data:image/s3,"s3://crabby-images/f6a1d/f6a1d89f3fd7cd043ec4363409ceb0325a27cd64" alt=""
Stage模型
data:image/s3,"s3://crabby-images/bd085/bd085ca890008d83c27fe3d5d1287dba23034970" alt=""
配置文件
UIAbitity生命周期
data:image/s3,"s3://crabby-images/a3468/a346857d601649ed681e77991f4b190e272947f9" alt=""
data:image/s3,"s3://crabby-images/a252f/a252fca9ae1f1acf742e340c19bd49cfdde63822" alt=""
组件的生命周期
data:image/s3,"s3://crabby-images/a7f52/a7f5211a368d899f63502b1c75aa08c62d07c0f3" alt=""
其中builder函数创建后的是和销毁前的是组件生命周期,可以在任意组件中使用,而页面的生命周期只能在@entry中使用
UIAlility启动模式
data:image/s3,"s3://crabby-images/3b6ee/3b6eee2d5468b7cabb87c05ba744a40391aa81a2" alt=""
data:image/s3,"s3://crabby-images/0620e/0620e2124740cd733cc589dca05e593d47d6c931" alt=""
data:image/s3,"s3://crabby-images/1c15f/1c15fc56d312e4e682606fca2b18f0562a61c4b3" alt=""
网络连接
http数据请求
data:image/s3,"s3://crabby-images/08f1a/08f1a53abb5fd5e513cc0b451772b09be9a6390d" alt=""