(本篇笔记对应课程第 12 - 13节)
P12《11.ArkUI组件-循环控制》
data:image/s3,"s3://crabby-images/b3ab4/b3ab46d35023e17cb5be5afad5f86464f6a90043" alt=""
data:image/s3,"s3://crabby-images/9908f/9908f18871ca4b4d6fd77b386b7e543e74159184" alt=""
forEach() 方法的使用方式:
data:image/s3,"s3://crabby-images/4270a/4270a70e9845cbce1783b03318a580a6980d0e05" alt=""
在预览界面点击红框的按钮,可以查看页面组件树结构:
将写好的静态代码改为使用forEach()循环渲染多项:
data:image/s3,"s3://crabby-images/ecac2/ecac2a1485a61a409db09fe86a3a9b7e11a6d327" alt=""
页面中定义好数据:
data:image/s3,"s3://crabby-images/54c54/54c54befdf7b408c6e461d2945f303d91e4b12c8" alt=""
使用forEach()遍历数据:
data:image/s3,"s3://crabby-images/f891c/f891c6485956398992f71a9ff14c6a83ea1586fc" alt=""
需求新增:
data:image/s3,"s3://crabby-images/822b4/822b412a3f07f517434af5fa2ebfe6023b795876" alt=""
data:image/s3,"s3://crabby-images/35515/35515f9ebdc9f3caa8baf8031e19421d1286e1fe" alt=""
data:image/s3,"s3://crabby-images/dcb75/dcb75bb93ec5d807e0cc34404fc38d1d8f22e606" alt=""
总结:
data:image/s3,"s3://crabby-images/63b41/63b416c6c77f498bd1606dfff8ac6e90117f03d2" alt=""
实践:
data:image/s3,"s3://crabby-images/ae4a9/ae4a9844d0c6be40bc55b8fe8600c12a993d3f07" alt=""
typescript
class Item {
name : string
image : ResourceStr
price : number
discount : number
constructor(name:string, image:ResourceStr, price:number, discount:number=0) {
this.name = name
this.image = image
this.price = price
this.discount = discount
}
}
@Entry
@Component
struct ItemsPage {
// 商品数据
private items: Array<Item> = [
new Item('FreeBuds 5i', $r('app.media.1'), 449),
new Item('FreeBuds Pro 3典藏版', $r('app.media.2'), 1449, 500),
new Item('问界 新M5', $r('app.media.3'), 291800),
new Item('WATCH 4 Pro', $r('app.media.4'), 4999),
new Item('华为智慧屏 S5', $r('app.media.5'), 5799)
]
build(){
Column(){
Row(){
Text('商品列表')
.fontSize(28)
}
.width('100%')
.height(60)
.padding({left:14, right:14})
.justifyContent(FlexAlign.Start)
Column({space:10}){
ForEach(this.items,
(item:Item) => {
Row({space:10}){
Image(item.image)
.width(100)
Column(){
Text(item.name)
.fontSize(18)
.fontColor('#444')
.fontWeight(FontWeight.Bold)
if(item.discount){
Text('原价¥:' + item.price)
.fontSize(18)
.fontColor('#888')
.decoration({type:TextDecorationType.LineThrough})
Text('折扣价¥:' + (item.price - item.discount))
.fontSize(18)
.fontColor('#6d6d')
Text('补贴¥:' + item.discount)
.fontSize(18)
.fontColor('#6d6d')
}else{
Text('¥:' + item.price)
.fontSize(18)
.fontColor('#6d6d')
}
}
.alignItems(HorizontalAlign.Start)
}
.width('100%')
.padding({left:14, right:14})
.backgroundColor('#fff')
.borderRadius(8)
}
)
}
.padding({left:10,right:10})
}
.width('100%')
.height('100%')
.backgroundColor('#eee')
}
}
P13《12.ArkUI组件-List》
data:image/s3,"s3://crabby-images/57c3c/57c3cd8f1111d0fa6c8c7376439d8e3961027697" alt=""
Column布局当列表数量过多超出屏幕之后,不能支持滚动效果:
data:image/s3,"s3://crabby-images/ea652/ea6527ebea891bada904a22b0f197c79521da221" alt=""
这时就需要用List组件替代Column组件了。注意:List是容器组件,它里面一定要有一个 ListItem ,但ListItem 不是容器组件。
data:image/s3,"s3://crabby-images/0c311/0c311e71ffaf3b8448629bc0d33ad9d1163b2ffb" alt=""
data:image/s3,"s3://crabby-images/0071f/0071f54d4cea906d9cbbeca86f5b3bd047ba7faf" alt=""
data:image/s3,"s3://crabby-images/0cb3e/0cb3e76ec7a9e030fc3d82fac39ad314087d2fc4" alt=""
data:image/s3,"s3://crabby-images/309db/309db0cf8669ee92ad816501ace9f94cc3049126" alt=""
实践:
data:image/s3,"s3://crabby-images/90474/904749afcf918679da1bbdb2ba05b60bbb881d21" alt=""
typescript
class Item {
name : string
image : ResourceStr
price : number
discount : number
constructor(name:string, image:ResourceStr, price:number, discount:number=0) {
this.name = name
this.image = image
this.price = price
this.discount = discount
}
}
@Entry
@Component
struct ItemsPage {
// 商品数据
private items: Array<Item> = [
new Item('FreeBuds 5i', $r('app.media.1'), 449),
new Item('FreeBuds Pro 3典藏版', $r('app.media.2'), 1449, 500),
new Item('问界 新M5', $r('app.media.3'), 291800),
new Item('WATCH 4 Pro', $r('app.media.4'), 4999),
new Item('华为智慧屏 S5', $r('app.media.5'), 5799),
new Item('华为智慧屏 S5', $r('app.media.5'), 5799),
new Item('华为智慧屏 S5', $r('app.media.5'), 5799),
new Item('华为智慧屏 S5', $r('app.media.5'), 5799)
]
build(){
Column(){
Row(){
Text('商品列表')
.fontSize(28)
}
.width('100%')
.height(60)
.padding({left:14, right:14})
.justifyContent(FlexAlign.Start)
List({space:10}){
ForEach(this.items,
(item:Item) => {
ListItem(){
Row({space:10}){
Image(item.image)
.width(100)
Column(){
Text(item.name)
.fontSize(18)
.fontColor('#444')
.fontWeight(FontWeight.Bold)
if(item.discount){
Text('原价¥:' + item.price)
.fontSize(18)
.fontColor('#888')
.decoration({type:TextDecorationType.LineThrough})
Text('折扣价¥:' + (item.price - item.discount))
.fontSize(18)
.fontColor('#6d6d')
Text('补贴¥:' + item.discount)
.fontSize(18)
.fontColor('#6d6d')
}else{
Text('¥:' + item.price)
.fontSize(18)
.fontColor('#6d6d')
}
}
.alignItems(HorizontalAlign.Start)
}
.width('100%')
.padding({left:14, right:14})
.backgroundColor('#fff')
.borderRadius(8)
}
}
)
}
.padding({left:10,right:10})
.layoutWeight(1)
}
.width('100%')
.height('100%')
.backgroundColor('#eee')
}
}