首页 > web前端 > uni-app > 正文

如何实现UniApp中的顶部选项卡切换不同数据

PHPz
发布: 2023-04-20 13:49:27
原创
4640人浏览过

随着移动端应用的普及,多数应用都需要一个选项卡功能,使得用户可以方便的在不同的选项卡间切换,显示不同的数据。在uniapp框架中,顶部选项卡切换不同数据也非常的简单。本文将详细介绍如何实现uniapp中的顶部选项卡切换不同数据的功能。

1. 基本思路

UniApp中实现顶部选项卡切换不同数据的思路很简单,就是通过点击选项卡切换不同的数据。在实现时,我们需要用到两个组件:

  • uni-tabs:UniApp中自带的选项卡组件;
  • uni-list-view:用于显示数据的列表组件。

其中,uni-tabs用于显示选项卡,当用户点击不同的选项卡时,uni-list-view会根据选项卡的不同,展示对应的数据。接下来,我们将逐步讲解如何使用这两个组件实现顶部选项卡切换不同数据的功能。

2. 创建 uni-tabs 组件

首先,我们创建一个 uni-tabs 组件,用于显示选项卡。具体代码如下:

<template>
  <div>
    <uni-tabs @click="changeTab">
      <uni-tab :title="tabsData[0]"></uni-tab>
      <uni-tab :title="tabsData[1]"></uni-tab>
      <uni-tab :title="tabsData[2]"></uni-tab>
    </uni-tabs>
  </div>
</template>

<script>
  export default {
    data() {
      return {
        tabsData: ['选项卡一', '选项卡二', '选项卡三']
      }
    },
    methods: {
      changeTab(e) {
        // 切换选项卡
      }
    }
  }
</script>
登录后复制

这段代码中,我们创建了一个 uni-tabs 组件,并在其中添加三个 uni-tab 组件。uni-tabs 组件是选项卡的容器,可以自适应屏幕大小,同时,该组件还提供了一些属性和事件。其中,我们需要用到的是点击事件 @click,通过该事件,可以获取用户点击的选项卡的信息。接下来,我们需要在 changeTab 方法中进行处理,实现选项卡的切换。

3. 设置 uni-list-view 组件

接下来,我们需要设置一个 uni-list-view 组件用于显示数据。具体代码如下:

腾讯智影-AI数字人
腾讯智影-AI数字人

基于AI数字人能力,实现7*24小时AI数字人直播带货,低成本实现直播业务快速增增,全天智能在线直播

腾讯智影-AI数字人 73
查看详情 腾讯智影-AI数字人
<template>
  <div>
    <uni-tabs @click="changeTab">
      <uni-tab :title="tabsData[0]"></uni-tab>
      <uni-tab :title="tabsData[1]"></uni-tab>
      <uni-tab :title="tabsData[2]"></uni-tab>
    </uni-tabs>
    <uni-list-view :ref="listViewRef" :list-data="currentData" :show-loading="true"></uni-list-view>
  </div>
</template>

<script>
  export default {
    data() {
      return {
        tabsData: ['选项卡一', '选项卡二', '选项卡三'],
        data: {
          tab1: [{...}, {...}, {...}],
          tab2: [{...}, {...}, {...}],
          tab3: [{...}, {...}, {...}]
        },
        currentData: [],
        listViewRef: 'listView'
      }
    },
    onReady() {
      this.changeTab({
        detail: {
          index: 0
        }
      })
    },
    methods: {
      changeTab(e) {
        // 切换选项卡
        let index = e.detail.index
        switch (index) {
          case 0:
            this.currentData = this.data.tab1
            break
          case 1:
            this.currentData = this.data.tab2
            break
          case 2:
            this.currentData = this.data.tab3
            break
          default:
            break
        }
        // 刷新列表数据
        if (this.$refs[this.listViewRef]) {
          this.$refs[this.listViewRef].refresh()
        }
      }
    }
  }
</script>
登录后复制

这里,我们创建了一个 uni-list-view 组件,并且设置了列表数据。具体来说,我们将数据分别存储在了 data.tab1data.tab2data.tab3 中,当用户点击不同的选项卡时,我们就可以根据选项卡的下标选择对应的列表数据。需要注意的是,在 changeTab 方法中,我们使用了 this.$refs[this.listViewRef].refresh() 方法,强制刷新列表数据。

4. 数据渲染

最后,我们需要将数据渲染到 uni-list-view 组件中。具体代码如下:

<template>
  <div>
    <uni-tabs @click="changeTab">
      <uni-tab :title="tabsData[0]"></uni-tab>
      <uni-tab :title="tabsData[1]"></uni-tab>
      <uni-tab :title="tabsData[2]"></uni-tab>
    </uni-tabs>
    <uni-list-view :ref="listViewRef" :list-data="currentData" :show-loading="true">
      <template v-slot:item="{ item }">
        <view class="list-item">{{ item }}</view>
      </template>
    </uni-list-view>
  </div>
</template>

<script>
  export default {
    data() {
      return {
        tabsData: ['选项卡一', '选项卡二', '选项卡三'],
        data: {
          tab1: ['数据1', '数据2', '数据3'],
          tab2: ['数据4', '数据5', '数据6'],
          tab3: ['数据7', '数据8', '数据9'],
        },
        currentData: [],
        listViewRef: 'listView'
      }
    },
    onReady() {
      this.changeTab({
        detail: {
          index: 0
        }
      })
    },
    methods: {
      changeTab(e) {
        // 切换选项卡
        let index = e.detail.index
        switch (index) {
          case 0:
            this.currentData = this.data.tab1
            break
          case 1:
            this.currentData = this.data.tab2
            break
          case 2:
            this.currentData = this.data.tab3
            break
          default:
            break
        }
        // 刷新列表数据
        if (this.$refs[this.listViewRef]) {
          this.$refs[this.listViewRef].refresh()
        }
      }
    }
  }
</script>
登录后复制

在这里,我们用了到了 v-slot:item 模板渲染方法,实现数据的渲染。具体来说,我们将列表项的数据使用 v-for 循环渲染到一个 view 组件中。

这样,我们就成功实现了在UniApp中使用 uni-tabsuni-list-view 组件实现顶部选项卡切换不同数据的功能。

以上就是如何实现UniApp中的顶部选项卡切换不同数据的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号