当前位置: 首页 > wzjs >正文

婚庆网站制作公司百度公司网站推广怎么做

婚庆网站制作公司,百度公司网站推广怎么做,青岛网站建设谁家好一些,搜索关键词可以过得网站文章目录 前言一、条件渲染1.1 if/else1.2 属性控制1.3 可见性 二、循环渲染三、滚动渲染3.1 下拉刷新3.2 上拉加载 前言 在声明式描述语句中开发者除了使用系统组件外,还可以使用渲染控制语句来辅助UI的构建,这些渲染控制语句包括控制组件是否显示的条…

文章目录

  • 前言
  • 一、条件渲染
    • 1.1 if/else
    • 1.2 属性控制
    • 1.3 可见性
  • 二、循环渲染
  • 三、滚动渲染
    • 3.1 下拉刷新
    • 3.2 上拉加载


前言

在声明式描述语句中开发者除了使用系统组件外,还可以使用渲染控制语句来辅助UI的构建,这些渲染控制语句包括控制组件是否显示的条件渲染语句,基于数组数据快速生成组件的循环渲染语句。


一、条件渲染

1.1 if/else

ArkTS提供了渲染控制的能力。条件渲染可根据应用的不同状态,使用if、else和else if渲染对应状态下的UI内容。

if (this.isShow){Image($r('app.media.foreground')).width(100)
}else{Image($r('app.media.startIcon')).width(100)
}

1.2 属性控制

可以使用三元表达式进行属性控制,比如元素高度、透明度、位置。

Image($r('app.media.startIcon')).width(this.isShow ? 100 : 0)

1.3 可见性

使用visibility属性进行元素的可见性控制。

Image($r('app.media.startIcon')).visibility(this.isShow? Visibility.Visible : Visibility.None)

二、循环渲染

ForEach接口基于数组类型数据来进行循环渲染,需要与容器组件配合使用,且接口返回的组件应当是允许包含在ForEach父容器组件中的子组件。例如,ListItem组件要求ForEach的父容器组件必须为List组件。

List() {ForEach(this.list, (item: GoodItem) => {ListItem() {Row({ space: 10 }) {Image(item.goods_img).borderRadius(8).width(120).height(200)Column() {Text(item.goods_name).fontWeight(FontWeight.Bold)Text("¥" + item.goods_price).fontColor(Color.Red).fontWeight(FontWeight.Bold)}.padding({top: 5,bottom: 5}).alignItems(HorizontalAlign.Start).justifyContent(FlexAlign.SpaceBetween).height(200).layoutWeight(1)}}.width('100%').padding(5)})
}

在这里插入图片描述

三、滚动渲染

当和页面做滚动交互时,主要分为下拉刷新和上拉加载。

3.1 下拉刷新

当页面下拉时,应该刷新页面数据。

Refresh({refreshing: $$this.refreshing,builder: this.refreshContent
}){List(){ForEach(this.list, (item:number)=>{ListItem(){Row(){Text(item.toString())}.width('100%').padding(20).border({width: {bottom: 1},color: Color.Gray})}})}
}.onRefreshing(()=>{setTimeout(()=>{this.list = Array(20).fill(Date.now())this.refreshing = false}, 1000)
})

Refresh组件:refreshing属性是指正在刷新状态的双向绑定,builder属性是指下拉刷新的显示页面组件(需要@Builder修饰符),onRefreshing是开始刷新事件函数。
builder代码如下:

@Builder
refreshContent(){Text('正在加载中...').width('100%').textAlign(TextAlign.Center).backgroundColor(Color.Pink)
}

3.2 上拉加载

当页面在底部并上拉时,页面应该请求新数据并加载到页面中。

Refresh({refreshing: $$this.refreshing,builder: this.refreshContent
}){List(){ForEach(this.list, (item:number)=>{ListItem(){Row(){Text(item.toString())}.width('100%').padding(20).border({width: {bottom: 1},color: Color.Gray})}})}.onScrollStart(()=>{// promptAction.showToast({message: '开始滚动'})this.isEnd = false}).onScrollStop(()=>{if (this.isEnd) {setTimeout(()=>{this.list.push(...Array(10).fill(Date.now()))promptAction.showToast({message: '已经添加10条数据'})this.scroller.scrollEdge(Edge.Bottom)}, 100)}}).onReachEnd(()=>{this.isEnd = true})
}.onRefreshing(()=>{setTimeout(()=>{this.list = Array(20).fill(Date.now())this.refreshing = false}, 1000)
})

上拉加载的时机:页面到底部,并且还在上拉刷新。就会加载数据到页面,并且页面定位到新加载数据处。
List组件:onScrollStart开始滚动事件函数,onScrollStop停止滚动事件函数,onReachEnd到达底部事件函数。

http://www.dtcms.com/wzjs/163217.html

相关文章:

  • 3000元建设个人网站短视频代运营方案策划书
  • 个人做收费网站html制作网页代码
  • 深圳高端网站建设美工如何做网站推广及优化
  • 我想做个卷帘门网站怎么做手机优化助手
  • 有哪些做批发的网站腾讯企点官网
  • cnzz站长统计怎么添加到博客网站网络商城应该如何推广
  • 企业官方网站建设宁波seo企业网络推广
  • 如何做网站服务器映射百度提交收录
  • adobe business catalyst wordpress百度关键词seo优化
  • 自家电脑做网站服务器w7花生壳恶意点击软件有哪些
  • 站长之家下载网络推广策划
  • 做设计英文网站营销案例100例小故事及感悟
  • 网站添加关键词会不会企业新闻稿发布平台
  • 幸福人寿保险公司官方网站电子保单打印百度广告投放公司
  • 深圳做官网公司网站优化排名技巧
  • 做板子焊接的网站的公司名字外贸建站与推广如何做
  • 本地wordpress 固定连接上海最专业的seo公司
  • 网站建设违约收录查询站长工具
  • wordpress速度优化插件青海seo技术培训
  • 域名网站大全备案查询站长之家
  • 做教育网站需要规划哪些内容常见的推广平台有哪些
  • wordpress ftp 安装长沙seo排名收费
  • 网站建设电子商务课总结和体会小熊代刷推广网站
  • 青岛市建设工程青岛关键词优化报价
  • 一级a做爰免费网站小程序开发平台有哪些
  • 聊城网站备案seo外链购买
  • 怎么做农产品垂直网站百度首页纯净版怎么设置
  • 温州网站设计如何宣传推广自己的产品
  • 苏州网站建设致宇搜索引擎营销的概念
  • 黑色门户网站源码巨量算数数据分析