# checkbox组件

# 基本结构

  • 结构
<template>
  <label class="xc-checkbox">
    <span class="xc-checkbox__input">
      <span class="xc-checkbox__inner"></span>
      <input type="checkbox" class="xc-checkbox__original">
    </span>
    <span class="xc-checkbox__label">
      <slot></slot>
      <template v-if="!$slots.default">{{label}}</template>
    </span>
  </label>
</template>
1
2
3
4
5
6
7
8
9
10
11
12
  • 样式
.xc-checkbox {
  color: #606266;
  font-weight: 500;
  font-size: 14px;
  position: relative;
  cursor: pointer;
  display: inline-block;
  white-space: nowrap;
  user-select: none;
  margin-right: 30px;
  .xc-checkbox__input {
    white-space: nowrap;
    cursor: pointer;
    outline: none;
    display: inline-block;
    line-height: 1;
    position: relative;
    vertical-align: middle;
    .xc-checkbox__inner {
      display: inline-block;
      position: relative;
      border: 1px solid #dcdfe6;
      border-radius: 2px;
      box-sizing: border-box;
      width: 14px;
      height: 14px;
      background-color: #fff;
      z-index: 1;
      transition: border-color .25s cubic-bezier(.71,-.46,.29,1.46),background-color .25s cubic-bezier(.71,-.46,.29,1.46);
      &:after {
        box-sizing: content-box;
        content: "";
        border: 1px solid #fff;
        border-left: 0;
        border-top: 0;
        height: 7px;
        left: 4px;
        position: absolute;
        top: 1px;
        transform: rotate(45deg) scaleY(0);
        width: 3px;
        transition: transform .15s ease-in .05s;
        transform-origin: center;
      }
    }
    .xc-checkbox__original {
      opacity: 0;
      outline: none;
      position: absolute;
      margin: 0;
      width: 0;
      height: 0;
      z-index: -1;
    }
  }
  .xc-checkbox__label {
    display: inline-block;
    padding-left: 10px;
    line-height: 19px;
    font-size: 14px;
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62

# 选中的样式

.xc-checkbox.is-checked {
  .xc-checkbox__input {
    .xc-checkbox__inner {
      background-color: #409eff;
      border-color: #409eff;
      &:after {
        transform: rotate(45deg) scaleY(1);
      }
    }
  }
  .xc-checkbox__label {
    color: #409eff;
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14

# 接收props数据

  props:{
    value: {
      type:Boolean,
      default:false
    },
    name: {
      type: String,
      default:''
    },
    label: {
      type: String,
      default:''
    }
  }
1
2
3
4
5
6
7
8
9
10
11
12
13
14

# 控制checkbox样式

<label class="xc-checkbox" :class="{'is-checked':model}">
1
上次更新: 2020/11/24 上午10:39:25