鸿蒙案例-首页Tabs和顶部搜素栏的实现

首页Tabs的实现

Tabs 组件可以实现页面内视图内容快速切换,包含 TabBar 和 TabContent 两个部分。

实现过程

1.设置 TabBar 和 TabContent ,设置多少个TabBar 和 TabContent取决于你有多少个切换项

(我有三个切换项所以我只创建了三个)

    TabContent(){
        Text('饮食记录页面')
      }
      .tabBar(this.TabBarBuilder($r('app.string.tab_record'),$r('app.media.ic_calendar'),0))

      TabContent(){
        Text('发现页面')
      }
      .tabBar(this.TabBarBuilder($r('app.string.tab_discover'),$r('app.media.discover'),1))

      TabContent(){
        Text('我的主页')
      }
      .tabBar(this.TabBarBuilder($r('app.string.tab_user'),$r('app.media.ic_user_portrait'),2))

2.设置标题显示在底部

 Tabs({barPosition:BarPosition.End}){
}

3.自定义TabBar的样式

 @Builder TabBarBuilder(title:ResourceStr,image:ResourceStr,index:number){
    Column({space:CommonConstants.SPACE_8}){
      Image(image)
        .width(22)
        .fillColor(this.selectColor(index))
      Text(title)
        .fontSize(14)
        .fontColor(this.selectColor(index))
    }
  }

4.判断是否为选中的标题项设置颜色

selectColor(index:number){
    return this.currentIndex == index ? $r('app.color.primary_color'):$r('app.color.gray')  //判断当前角标与我的是否是一个,如果是则是主色调,若不是则是灰色
  }

代码实现

import { CommonConstants } from '../common/constants/CommonConstants'
@Entry
@Component
struct Index {
  @State currentIndex:number = 0

  @Builder TabBarBuilder(title:ResourceStr,image:ResourceStr,index:number){ //自定义样式.  index为角标用于控制样式
    Column({space:CommonConstants.SPACE_8}){
      Image(image)
        .width(22)
        .fillColor(this.selectColor(index))
      Text(title)
        .fontSize(14)
        .fontColor(this.selectColor(index))
    }
  }

  selectColor(index:number){ //选择一个颜色
    return this.currentIndex == index ? $r('app.color.primary_color'):$r('app.color.gray')  //判断当前角标与我的是否是一个,如果是则是主色调,若不是则是灰色
  }

  build() {
    Tabs({barPosition:BarPosition.End}) { //Tabs组件实现视图内容快速切换.barPosition:BarPosition.End设置标题在底部
      TabContent(){
        Text('饮食记录页面')
      }
      .tabBar(this.TabBarBuilder($r('app.string.tab_record'),$r('app.media.ic_calendar'),0))

      TabContent(){
        Text('发现页面')
      }
      .tabBar(this.TabBarBuilder($r('app.string.tab_discover'),$r('app.media.discover'),1))

      TabContent(){
        Text('我的主页')
      }
      .tabBar(this.TabBarBuilder($r('app.string.tab_user'),$r('app.media.ic_user_portrait'),2))
    }
    .width('100%')
    .height('100%')
    .onChange(index=>this.currentIndex=index) //记录切换角标
    .vertical(false) //标题为水平布局,true则为纵向布局
  }
}

页面效果

顶部搜素栏的实现

实现过程

1.设置头部搜素栏 

 Column(){
      //1.头部搜素栏
      SearchHeader()
      //2.统计卡片
      Text('统计卡片')
      //3.记录列表
      Text('记录列表')
    }
    .width('100%')
    .height('100%')
    .backgroundColor($r('app.color.index_page_background'))

2.利用Search搜索框组件实现搜索框效果

  Row({space:CommonConstants.SPACE_6}){
      Search({placeholder:'搜素饮食或运动信息'}) 
        .textFont({size:18})
        .layoutWeight(1)

3.利用Badge信息标记容器组件实现邮箱计数效果

  Badge({count:1,position:BadgePosition.RightTop,style:{fontSize:14}}){ 
        Image($r('app.media.ic_public_email'))
          .width(24)
      }

代码实现

import SearchHeader from './SearchHeader'
@Component
export default struct RecordIndex {
  build() {
    Column(){
      //1.头部搜素栏
      SearchHeader()
      //2.统计卡片
      Text('统计卡片')
      //3.记录列表
      Text('记录列表')
    }
    .width('100%')
    .height('100%')
    .backgroundColor($r('app.color.index_page_background'))
  }
}
import { CommonConstants } from '../../common/constants/CommonConstants'
@Component
 export default struct SearchHeader {
  build() {
    Row({space:CommonConstants.SPACE_6}){
      Search({placeholder:'搜素饮食或运动信息'}) //搜索框组件,适用于浏览器的搜索内容输入框等应用场景。
        .textFont({size:18})
        .layoutWeight(1)

      Badge({count:1,position:BadgePosition.RightTop,style:{fontSize:14}}){ //Badge用于信息标记的容器组件
        Image($r('app.media.ic_public_email'))
          .width(24)
      }

    }
    .width(CommonConstants.THOUSANDTH_940)
  }
}

页面效果

总结

    Tabs组件的页面组成包含两个部分,分别是TabContent和TabBar。TabContent是内容页,TabBar是导航页签栏。

    切换指定页签需要使用TabsController,TabsController是Tabs组件的控制器,用于控制Tabs组件进行页签切换。通过TabsController的changeIndex方法来实现跳转至指定索引值对应的TabContent内容。不支持一个TabsController控制多个Tabs组件。

   搜索框组件Search,适用于浏览器的搜索内容输入框等应用场景。该组件从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容的起始版本。Badge组件可以附加在单个组件上用于信息标记的容器组件。支持单个子组件。子组件类型:系统组件和自定义组件,支持渲染控制类型(if/elseForEachLazyForEach)。

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要实现 element-plus tabs 切换动画效果,可以使用 CSS 过渡(transition)属性以及在切换时添加/移除 CSS 类名的方式来实现。具体方法如下: 1. 在选项卡(tab)容器上添加 CSS 类名,比如 "tab-container"。 2. 在选项卡头部(tab header)中的每个选项卡按钮上添加一个自定义属性,比如 "data-tab-index",值为对应选项卡的索引,以便在后面的代码中使用。 3. 使用 CSS 过渡属性来设置选项卡内容容器(tab content)的动画效果,例如: ```css .tab-content { transition: opacity .3s; } .tab-content-enter-active, .tab-content-leave-active { opacity: 0; } ``` 这里使用 opacity 属性来控制选项卡内容容器的可见性,在过渡时将其从 1 到 0。 4. 在选项卡按钮点击事件的处理函数中,先获取当前选项卡的索引,然后根据索引找到对应的选项卡内容容器,并添加 / 移除 CSS 类名,以实现过渡效果。例如: ```javascript const container = document.querySelector('.tab-container') const tabs = [...container.querySelectorAll('.tab-header button')] const contents = [...container.querySelectorAll('.tab-content')] tabs.forEach((tab, index) => { tab.addEventListener('click', () => { const content = contents[index] if (!tab.classList.contains('active')) { tabs.forEach(tab => tab.classList.remove('active')) tab.classList.add('active') contents.forEach(content => content.classList.remove('active')) content.classList.add('active') } }) }) ``` 这里使用 `classList` 属性来添加 / 移除 CSS 类名,以触发过渡效果。同时需要注意的是,为了在后面的代码中使用,在选项卡容器、选项卡头部和选项卡内容容器中都需要添加相应的 CSS 类名。 ### 回答2: 要实现element-plus tabs切换动画效果,可以遵循以下步骤: 步骤1:在项目中安装element-plus组件库。可以使用npm或yarn命令来安装,具体命令为:npm install element-plus 或 yarn add element-plus。 步骤2:在项目的入口文件中引入element-plus的样式文件。可以在main.js或App.vue文件中添加以下代码引入样式: import 'element-plus/lib/theme-chalk/index.css'; 步骤3:在需要使用tabs组件的页面中引入和使用element-plus的tabs组件。可以在页面的template部分添加以下代码: <template> <el-tabs v-model="activeTab" type="border-card"> <el-tab-pane label="Tab1" name="1"> Content of Tab 1 </el-tab-pane> <el-tab-pane label="Tab2" name="2"> Content of Tab 2 </el-tab-pane> <el-tab-pane label="Tab3" name="3"> Content of Tab 3 </el-tab-pane> </el-tabs> </template> 步骤4:为tabs组件添加切换动画效果。可以使用element-plus提供的transition组件来实现动画效果。在tabs组件外面包裹一个transition组件,并设置相应的属性,如name、enter-active-class等,实现切换时的动画效果。例如: <template> <transition name="fade" enter-active-class="animated fadeIn" leave-active-class="animated fadeOut"> <el-tabs v-model="activeTab" type="border-card"> ... </el-tabs> </transition> </template> 步骤5:在样式文件中为切换动画效果设置相应的CSS样式。可以使用动画库(如animate.css)提供的动画效果,或自定义CSS样式来实现。例如: .fade-enter-active, .fade-leave-active { transition: opacity 0.5s; } .fade-enter, .fade-leave-to { opacity: 0; } 这样就可以实现用element-plus的tabs组件切换时的动画效果。根据需要调整步骤4和步骤5中的属性和样式,在页面中实现满足需求的动画效果。 ### 回答3: 要实现 element-plus tabs 切换动画效果,可以按照以下步骤进行: 1. 使用 element-plus 的 Tabs 组件创建页面的 tab 标签。 2. 在 Tabs 组件中,利用事件监听器监控 tab 切换的过程。可以使用 `@tab-click` 事件监听器来实现。 3. 在监听器中,使用 CSS 动画或过渡来实现 tab 切换的动画效果。 4. CSS 动画可以使用 `@keyframes` 来定义动画的关键帧,然后将动画应用到 Tabs 组件上。 5. 过渡效果可以使用 `transition` 属性来实现,在样式改变的时候添加过渡效果。 6. 可以根据需要,设置不同的动画效果,例如淡入淡出、滑动、放大缩小等等。 7. 使用动画效果时要注意性能和流畅度,避免影响页面加载速度和交互体验。 8. 经过以上步骤,即可实现 element-plus tabs 的切换动画效果。 总的来说,实现 element-plus tabs 切换动画效果的关键是将 CSS 动画或过渡应用到 Tabs 组件上,并利用事件监听器来触发动画效果。同时要注意选择适合的动画效果,以增强页面的交互效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值