vue:手写一个单选框/多选框


原链接icon-default.png?t=L892https://www.jb51.net/css/735639.html

一、效果:

二、代码:

<template>
  <div>
    <div id="main">

      <h1>多选</h1>
      <div class="wrap">
        <input type="checkbox" name="1" id="item1" />
        <label for="item1">
          <div class="item">
            <div class="content">
              1
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
      <div class="wrap">

        <input type="checkbox" name="1" id="item2" />
        <label for="item2">
          <div class="item">
            <div class="content">
              2
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
      <div class="wrap">

        <input type="checkbox" name="1" id="item3" />
        <label for="item3">
          <div class="item">
            <div class="content">
              3
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
      <div class="wrap">

        <input type="checkbox" name="1" id="item4" />
        <label for="item4">
          <div class="item">
            <div class="content">
              4
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
      <div class="wrap">

        <input type="checkbox" name="1" id="item5" />
        <label for="item5">
          <div class="item">
            <div class="content">
              5
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>

      <h1>单选</h1>
      <div class="wrap">
        <input type="radio" name="1" id="item6" />
        <label for="item6">
          <div class="item">
            <div class="content">
              1
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
      <div class="wrap">

        <input type="radio" name="1" id="item7" />
        <label for="item7">
          <div class="item">
            <div class="content">
              2
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
      <div class="wrap">

        <input type="radio" name="1" id="item8" />
        <label for="item8">
          <div class="item">
            <div class="content">
              3
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
      <div class="wrap">

        <input type="radio" name="1" id="item9" />
        <label for="item9">
          <div class="item">
            <div class="content">
              4
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
      <div class="wrap">

        <input type="radio" name="1" id="item10" />
        <label for="item10">
          <div class="item">
            <div class="content">
              5
            </div>
            <img src="ico_checkon.svg" />
          </div>
        </label>
      </div>
    </div>

  </div>
</template>

<script>
  export default {
    name: "",
    components: {

    },
    data() {
      return {

      }
    },
    props: {

    },
    methods: {

    },
  }
</script>

<style lang="scss" scoped>
  #main {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
  }

  .wrap {
    position: relative;
    margin: 10px;
  }

  .item {
    width: 100px;
    height: 100px;
    background-color: #9E9E9E;
    position: relative;
    box-shadow: 0 0 0 3px #dbe0e3;
    transition: all 0.5s;
    cursor: pointer;
  }

  .item img {
    width: 20px;
    height: 20px;
    position: absolute;
    bottom: 0px;
    right: 0px;
    opacity: 0;
  }

  input[type="radio"],
  input[type="checkbox"] {
    display: none;
  }

  input:checked+label .item {
    box-shadow: 0 0 0 3px #00a3ff;
    color: #FFFFFF;
    background-color: #efad4c;
  }

  input:checked+label .item img {
    opacity: 1;
  }

  .content {
    font-size: 30px;
    text-align: center;
    line-height: 100px;
  }
</style>

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值