zoukankan      html  css  js  c++  java
  • 修改 input[type="radio"] 和 input[type="checkbox"] 的默认样式

    表单中,经常会使用到单选按钮和复选框,但是,input[type="radio"] 和 input[type="checkbox"] 的默认样式在不同的浏览器或者手机上,显示的效果总是不统一,而且难以修改器样式。

    input[type="radio"] 样式定制

    代码:

    <form>
        <p>
            <input type="radio" name="gender" id="male" value="male">
            <label for="male">男士</label>
        </p>
        <p>
            <input type="radio" name="gender" id="female" value="female">
            <label for="female">女士</label>
        </p>
    </form>
    

    css 样式

    input[type="radio"] {
    	height: 22px;
    	 22px;
    	margin-right: 10px;
    	display: none;
    }
    input[type="radio"] + label::before {
        content: "a0"; /*不换行空格*/
        display: inline-block;
        vertical-align: middle;
        font-size: 18px;
         18px;
        height: 18px;
        margin-right: 10px;
        border-radius: 50%;
    	border: 1px solid #003c66;
    	background: #fff;
    	line-height: 22px;
    	box-sizing: border-box;
    }
    input[type="radio"]:checked + label::before {
        background-color: #003c66;
        background-clip: content-box;
        padding: 3px;
    }
    
    

    效果如图:

    单选框

    input[type="checkbox"] 样式定制

    代码:

    <form>
        <input id="select_all" name="select_all" type="checkbox">
        <label for="select_all"> <i></i>选择</label>
    </form>
    

    css 样式

    input[type="checkbox"] {
        display: none;
    }
    
    input[type="checkbox"]+label>i {
        display: inline-block;
         20px;
        height: 20px;
        border: 1px solid #bbb;
        background: #bbb;
        margin-right: 10px;
        vertical-align: middle;
    }
    
    input[type="checkbox"]:checked+label>i {
        position: relative;
    }
    
    input[type="checkbox"]:checked+label>i::before {
        content: '';
        position: absolute;
         12px;
        height: 18px;
        color: black;
        border-bottom: 1px solid green;
        border-right: 1px solid green;
        left: 50%;
        top: 20%;
        transform-origin: center;
        transform: translate(-50%, -30%) rotate(40deg);
        -webkit-transform: translate(-50%, -30%) rotate(40deg);
    }
    

    效果如图:

    复选框

  • 相关阅读:
    spring boot 上传文件大小限制
    axios全局配置
    springboot 时间类型配置
    mybatis 全查 分页 模糊查询一体
    Vue响应式原理底层代码模拟实现
    浅谈vue响应式原理及发布订阅模式和观察者模式
    Vue Router的原理及history模式源码实现
    Vue路由之Hash模式和history模式的区别及History模式的解决办法
    webpack4.X之complier方法的实现及make前流程回顾
    webpack4.X之EntryOptionPlugin流程书写
  • 原文地址:https://www.cnblogs.com/cckui/p/9411498.html
Copyright © 2011-2022 走看看