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

wordpress主题销售seo优化报价公司

wordpress主题销售,seo优化报价公司,做有搜索功能的网站,b2b网上交易平台有哪些大家周末好呀,今天继续分享仓颉语言开发商城应用的实战教程,今天要做的是tabbar。 大家都知道ArkTs有Tabs和TabContent容器,能够实现上图的样式,满足基本的使用需求。而仓颉就不同了,它虽然也有这两个组件,…

大家周末好呀,今天继续分享仓颉语言开发商城应用的实战教程,今天要做的是tabbar。

大家都知道ArkTs有Tabs和TabContent容器,能够实现上图的样式,满足基本的使用需求。而仓颉就不同了,它虽然也有这两个组件,但是它的tabbar参数只支持传入图片或者文字,不能像ArkTs那样能传入组件,所以在仓颉语言中官方的tabbar局限性非常大。

给大家实操讲解一下,下面是一段Tabs的基本写法:

Tabs(BarPosition.End, this.controller){TabContent(){Text('页面1')}TabContent(){Text('页面2’)}
}

如果你要设置tabbar的样式,需要在TabContent下添加tabbar属性,然后你会发现tabbar只有唯二的两个参数:

TabContent(){Text('页面1')}.tabBar(icon: CJResource, text: CJResource)

设置完之后它长这样:

这样就无法满足我们的需求,所以我们需要自定义。

每一个tabbar元素都有一个图片组件和一个文字组件,我给它写出来:

Column {Image(item.selectIcon).width(28).height(28)Text(item.title).fontSize(15).fontColor(0xd84642).margin(top: 3)}

然后它需要有一个选中状态,难受的是仓颉不支持三元表达式,所以我只能写if语句:

Column {if(this.currenttabIndex == index){Image(item.selectIcon).width(28).height(28)Text(item.title).fontSize(15).fontColor(0xd84642).margin(top: 3)}else {Image(item.icon).width(28).height(28)Text(item.title).fontSize(15).fontColor(Color.GRAY).margin(top: 3)}}

它还需要一个点击事件:

Column {if(this.currenttabIndex == index){Image(item.selectIcon).width(28).height(28)Text(item.title).fontSize(15).fontColor(0xd84642).margin(top: 3)}else {Image(item.icon).width(28).height(28)Text(item.title).fontSize(15).fontColor(Color.GRAY).margin(top: 3)}}
.onClick({evet => this.currenttabIndex = index;this.controller.changeIndex(Int32(this.currenttabIndex))})

这样一个元素就写好了,接下来我只要循环添加几个元素,一个完整的tabbar就写好了,这里大家也要注意一下仓颉中foreach的写法:

Row {ForEach(this.tabList, itemGeneratorFunc: {item: TabItem, index: Int64 =>Column {if(this.currenttabIndex == index){Image(item.selectIcon).width(28).height(28)Text(item.title).fontSize(15).fontColor(0xd84642).margin(top: 3)}else {Image(item.icon).width(28).height(28)Text(item.title).fontSize(15).fontColor(Color.GRAY).margin(top: 3)}}.onClick({evet => this.currenttabIndex = index;this.controller.changeIndex(Int32(this.currenttabIndex))})})
}
.width(100.percent)
.height(60)
.alignItems(VerticalAlign.Center)
.justifyContent(FlexAlign.SpaceAround)

最后我们还是需要官方的Tabs容器来添加页面,你只要不设置tabbar属性底部导航栏区域就是空白的,正好把我们自定义的tabbar放上,下面是完整的示例代码:

let tabList: Array<TabItem> = [TabItem(@r(app.media.shop_tab_00), @r(app.media.shop_tab_01), '首页'),TabItem(@r(app.media.shop_tab_10), @r(app.media.shop_tab_11), '购物车'),TabItem(@r(app.media.shop_tab_20), @r(app.media.shop_tab_21), '我的')]
@State
var currenttabIndex:Int64 = 0Stack(Alignment.Bottom) {Tabs(BarPosition.End, this.controller){TabContent(){home()}TabContent(){shopcar()}TabContent(){mine()}}.barHeight(60).scrollable(false).animationDuration(0)Row {ForEach(this.tabList, itemGeneratorFunc: {item: TabItem, index: Int64 =>Column {if(this.currenttabIndex == index){Image(item.selectIcon).width(28).height(28)Text(item.title).fontSize(15).fontColor(0xd84642).margin(top: 3)}else {Image(item.icon).width(28).height(28)Text(item.title).fontSize(15).fontColor(Color.GRAY).margin(top: 3)}}.onClick({evet => this.currenttabIndex = index;this.controller.changeIndex(Int32(this.currenttabIndex))})})
}
.width(100.percent)
.height(60)
.alignItems(VerticalAlign.Center)
.justifyContent(FlexAlign.SpaceAround)
}

以上就是仓颉语言自定义tabbar的实现过程,感谢阅读。#HarmonyOS语言##仓颉##购物#

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

相关文章:

  • 网站制作最seo教程免费分享
  • 免费怎么制作公司网站网站策划方案案例
  • 怎么用hbuilder做网站百度爱采购推广效果怎么样?
  • b2c电子商务网站.市场营销是做什么的
  • 门户网站模版市场调研报告最佳范文
  • 网站 欣赏南宁百度seo排名优化
  • 北京网站设计制作飞沐国际新闻最新消息战争
  • 接单做公司网站站群seo黑帽多久入门
  • wordpress合理使用cookie搜索引擎优化的七个步骤
  • 中国建设银行的网站2023年4月疫情恢复
  • 怎样建设百度网站站长聚集地
  • 网站建设需要注意些什么现在百度推广有用吗
  • 福州精美个人网站建设公司百度信息流推广
  • 网站策划岗位要求软文发稿平台有哪些
  • 上海企业网站的建设关键词排名零芯互联关键词
  • 定制建站方案杭州网络推广有限公司
  • c2c网站方案营销推广平台
  • 网站建设明细报价表 xls全网搜索关键词查询
  • 做外挂网站广告投放方案
  • 北京智能网站建设哪里有软件开发工资一般多少
  • 网站数据库到期优化网站服务
  • 成都网站优化哪家好营销网店推广的软文
  • 邢台网站制作多少钱百度点击软件还有用吗
  • wordpress怎么发布鱼头seo软件
  • 上海网络推广公司排名郑州seo顾问热狗
  • 站长工具官方网石家庄疫情
  • wordpress下安装论坛 伪静态苏州seo关键词优化软件
  • 怎样做婚庆网站抖音seo招商
  • 营销型网站建设模板下载南宁seo服务优化
  • 怎么做营销型网站设计今日关键词