uni-app 排行榜样式插件需求

发布于 1周前 作者 h691938207 来自 Uni-App

uni-app 排行榜样式插件需求

1 回复

针对您提出的uni-app排行榜样式插件需求,这里提供一个基本的排行榜组件实现代码案例。此案例展示了如何创建一个简单的排行榜列表,并包含排名、用户昵称和分数等信息。您可以根据实际需求进一步调整和扩展功能。

排行榜组件代码

首先,创建一个名为RankList.vue的组件文件:

<template>
  <view class="rank-list">
    <view v-for="(item, index) in rankList" :key="index" class="rank-item">
      <text class="rank">{{ index + 1 }}</text>
      <text class="nickname">{{ item.nickname }}</text>
      <text class="score">{{ item.score }}</text>
    </view>
  </view>
</template>

<script>
export default {
  name: 'RankList',
  props: {
    rankList: {
      type: Array,
      required: true
    }
  }
}
</script>

<style scoped>
.rank-list {
  padding: 10px;
}
.rank-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid #ddd;
}
.rank {
  width: 30px;
  text-align: center;
  font-weight: bold;
}
.nickname {
  flex: 1;
  text-align: left;
}
.score {
  width: 80px;
  text-align: right;
  color: #f56c6c;
}
</style>

使用排行榜组件

在需要使用排行榜的页面中引入并使用RankList组件。例如,在index.vue中:

<template>
  <view>
    <RankList :rankList="rankData" />
  </view>
</template>

<script>
import RankList from '@/components/RankList.vue';

export default {
  components: {
    RankList
  },
  data() {
    return {
      rankData: [
        { nickname: 'Alice', score: 950 },
        { nickname: 'Bob', score: 880 },
        { nickname: 'Charlie', score: 820 },
        // 更多数据...
      ]
    };
  }
}
</script>

说明

  • RankList.vue组件接受一个名为rankList的prop,该prop是一个包含用户昵称和分数的数组。
  • 在组件内部,使用v-for指令遍历rankList数组,生成排行榜列表项。
  • 每个列表项包含排名(通过索引计算)、昵称和分数。
  • 通过简单的样式设置,使排行榜看起来更加美观。

您可以根据实际需求,进一步添加功能,如数据排序、刷新、用户交互等。希望这个示例能帮助您快速实现排行榜功能。

回到顶部