Badge

Install

import Vue from 'vue';
import { Badge } from 'vant';

Vue.use(Badge);

Usage

Basic Usage

<van-badge :content="5">
  <div class="child" />
</van-badge>
<van-badge :content="10">
  <div class="child" />
</van-badge>
<van-badge content="Hot">
  <div class="child" />
</van-badge>
<van-badge dot>
  <div class="child" />
</van-badge>

<style>
  .child {
    width: 40px;
    height: 40px;
    background: #f2f3f5;
    border-radius: 4px;
  }
</style>

Max

<van-badge :content="20" max="9">
  <div class="child" />
</van-badge>
<van-badge :content="50" max="20">
  <div class="child" />
</van-badge>
<van-badge :content="200" max="99">
  <div class="child" />
</van-badge>

Custom Color

<van-badge :content="5" color="#1989fa">
  <div class="child" />
</van-badge>
<van-badge :content="10" color="#1989fa">
  <div class="child" />
</van-badge>
<van-badge dot color="#1989fa">
  <div class="child" />
</van-badge>

Custom Content

Use content slot to custom :content of badge.

<van-badge>
  <div class="child" />
  <template #content>
    <van-icon name="success" class="badge-icon" />
  </template>
</van-badge>
<van-badge>
  <div class="child" />
  <template #content>
    <van-icon name="cross" class="badge-icon" />
  </template>
</van-badge>
<van-badge>
  <div class="child" />
  <template #content>
    <van-icon name="down" class="badge-icon" />
  </template>
</van-badge>
.badge-icon {
  display: block;
  font-size: 10px;
  line-height: 16px;
}

Standalone

<van-badge :content="20" />

<van-badge :content="200" max="99" />

API

Props

Attribute Description Type Default
content Badge content number | string -
color Background color string #ee0a24
dot Whether to show dot boolean false
max Max valueshow {max}+ when exceedonly works when content is number number | string -

Slots

Name Description
default Default slot
content Custom badge content

Less Variables

How to use: Custom Theme.

Name Default Value Description
@badge-size 16px -
@badge-color @white -
@badge-padding 0 3px -
@badge-font-size @font-size-sm -
@badge-font-weight @font-weight-bold -
@badge-border-width @border-width-base -
@badge-background-color @red -
@badge-dot-color @red -
@badge-dot-size 8px -
@badge-font-family -apple-system-font, Helvetica Neue, Arial, sans-serif -