当前位置:首页 > VUE

vue badge 实现方法

2026-01-18 08:36:02VUE

使用组件库实现 Badge

Vue 生态中主流组件库(如 Element UI、Ant Design Vue、Vuetify 等)均提供现成的 Badge 组件。

以 Element UI 为例:

<el-badge :value="12" class="item">
  <el-button>评论</el-button>
</el-badge>

Ant Design Vue 示例:

vue badge 实现方法

<a-badge count=5>
  <a-avatar shape="square"/>
</a-badge>

自定义 Badge 组件

通过 CSS 绝对定位实现基础样式:

<template>
  <div class="badge-container">
    <slot></slot>
    <span class="badge" v-if="count">{{ count }}</span>
  </div>
</template>

<script>
export default {
  props: ['count']
}
</script>

<style>
.badge-container {
  position: relative;
  display: inline-block;
}

.badge {
  position: absolute;
  top: -8px;
  right: -8px;
  background: red;
  color: white;
  border-radius: 50%;
  width: 16px;
  height: 16px;
  font-size: 12px;
  text-align: center;
  line-height: 16px;
}
</style>

动态 Badge 样式

根据数值变化调整样式:

vue badge 实现方法

computed: {
  badgeClass() {
    return {
      'badge': true,
      'badge-danger': this.count > 10,
      'badge-warning': this.count <= 10
    }
  }
}

动画效果实现

使用 Vue 过渡动画:

<transition name="bounce">
  <span class="badge" v-if="show">{{ count }}</span>
</transition>

<style>
.bounce-enter-active {
  animation: bounce-in 0.5s;
}
@keyframes bounce-in {
  0% { transform: scale(0) }
  50% { transform: scale(1.5) }
  100% { transform: scale(1) }
}
</style>

服务端数据绑定

结合 Vuex 或 API 数据:

data() {
  return {
    notificationCount: 0
  }
},
mounted() {
  fetch('/api/notifications/count')
    .then(res => res.json())
    .then(data => {
      this.notificationCount = data.count
    })
}

标签: 方法vue
分享给朋友:

相关文章

vue 移动端实现签名

vue 移动端实现签名

Vue 移动端签名实现方法 在移动端实现签名功能,可以通过HTML5的Canvas结合触摸事件完成。以下是具体实现步骤: 使用Canvas绘制签名 安装vue-signature-pad插件或直…

在线脑图 vue 实现

在线脑图 vue 实现

在线脑图 Vue 实现方案 使用开源库实现 推荐使用 mind-elixir 或 jsmind 这类开源库,它们专为脑图设计且支持 Vue 集成。 安装依赖: npm install mind…

vue实现表格多行修改

vue实现表格多行修改

实现多行编辑表格 在Vue中实现表格的多行编辑功能,可以通过以下方法完成。这里以Element UI的表格组件为例,但思路适用于其他UI库或原生实现。 数据准备 定义表格数据和编辑状态管理变量:…

vue路由实现内部切换

vue路由实现内部切换

Vue 路由实现内部切换的方法 Vue Router 是 Vue.js 官方的路由管理器,用于实现单页应用(SPA)的页面切换。以下是几种常见的内部路由切换方式: 使用 <router-lin…

vue使用vr实现标注

vue使用vr实现标注

Vue 中使用 VR 实现标注的方法 在 Vue 项目中结合 VR 技术实现标注功能,可以通过 WebXR 和 Three.js 等库实现。以下为具体实现方法: 安装依赖 确保项目中已安装 Thr…

vue实现3d宇宙

vue实现3d宇宙

Vue实现3D宇宙效果 使用Three.js库 Three.js是一个强大的JavaScript 3D库,可以轻松集成到Vue项目中。安装Three.js依赖: npm install three…