• html、css、js三件套实现的操作栏(模仿antDesign的单选框通过js实现单选框激活效果)


    html、css、js三件套实现的操作栏(模仿antDesign的单选框通过js实现单选框激活效果)

    1,效果:

     2,代码:

    Model_antDesign.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>操作栏</title>
        <link rel="stylesheet" type="text/css" href="ys-Model_antDesign.css">
        <link rel="stylesheet" type="text/css" href="Model_antDesign.css">
    </head>
    <body>
    <section>
        <div class="container">
            <!-- 操作栏  -->
            <form method="post" >
                <div class="operation">
                    <!-- 操作块-->
                    <div class="ipt-box">
                        <label for="stuName">学生姓名</label>
                        <input class="ipt" type="text" name="stuName" id="stuName" autocomplete="off">
                    </div>
                    <div class="ipt-box">
                        <label>班级</label>
                        <select class="ipt grade">
                            <option class="hidden">请选择班级:</option>
                            <option>初一1班</option>
                            <option>初二1班</option>
                            <option>初三1班</option>
                        </select>
                    </div>
                    <div class="ipt-box sex">
                        <label>性别</label>
                        <!-- 自定义的单选框插件  -->
                        <div class="ys-radio-group">
                            <div class="ys-radio active" data-value="man" data-show="男"></div>
                            <div class="ys-radio" data-value="woMan" data-show="女"></div>
                        </div>
                    </div>
                    <div class="ipt-box">
                        <label for="age">年龄</label>
                        <input class="ipt" type="text" name="age" id="age" autocomplete="off">
                    </div>
                    <input class="btn" type="submit" value="提交学生信息">
                </div>
            </form>
        </div>
    </section>
    </body>
    <script type="text/javascript" src="ys-Model_antDesign.js"></script>
    <script type="text/javascript" src="Model_antDesign.js"></script>
    </html>

    ❀ Model_antDesign.css

    body{
        margin: 0;
    }
    .container{
        width: 1077px;
        margin: 50px auto;
    }
    .hidden{
        display: none;
    }
    .operation{
        display: flex;
        align-items: center;
    }
    /*   模仿antDesign的输入框设计---通用输入框样式  */
    .ipt{
        height:32px;
        border: 1px solid #d9d9d9;
        box-sizing: border-box;
        outline: none;
    /* 过渡边框颜色动画*/
        transition: all .2s linear;
        border-radius: 3px;
        color: #262626;
        text-indent: .8em;
    }
    .ipt:hover{
        border: 1px solid #1890ff;
    }
    .ipt:focus{
        box-shadow: 0 0 0 2px #d1e9ff;
    }
    .operation .ipt-box + .ipt-box {
        margin-left: 20px;
    }
    .operation .ipt-box .grade{
        width: 120px;
    }
    /* 模仿antDesign的按钮设计--通用按钮设计 */
    .btn{
        display: inline-block;
        /* 92px;*/
        /*height:30px;*/
        padding: 8px 15px;
        /*box-sizing:border-box;*/
        background-color: #1890ff;
        color: white;
        border: none;
        border-radius: 3px;
        transition: all .2s linear;
        cursor: pointer;
    }
    .btn:hover{
        border: 1px solid #40a9ff;
    }
    .btn:active{
        box-shadow: 0 0 0 2px #d1e9ff;
    }
    .operation .btn{
        margin-left: 20px;
    }

    ys-Model_antDesign.css

    /**
    * 功能:自定义插件的css文档
    * 作者:一乐
    * 时间:2021/7/29
    * 地点:一乐乐家园
    */
    
    .ys-radio{
        width: 16px;
        height: 16px;
        box-sizing:border-box;
        border: 1px solid #f1f1f1;
        border-radius: 50%;
        cursor: pointer;
        transition: all .2s linear;
    
    }
    .ys-radio:hover{
        border: 1px solid #1890ff;
    }
    
    /* 实心圆 */
    /* 实心圆居中 */
    /*激活后实心圆立马消失的bug~~~~因为active 是作为类标签非那个伪类啦*/
    .ys-radio.active{
        border: 1px solid #1890ff;
        box-shadow: 0 0 0 2px #d1e9ff;
        display: flex;
        align-items: center;
        justify-content: center;
        position:relative;
    }
    .ys-radio.active:after{
        content:'';
        display: inline-block;
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background-color: #1890ff;
        transition: all .2s linear;
    }
    .operation .ipt-box.sex{
        display: flex;
        align-items: center;
    }
    .operation .ipt-box .ys-radio-group{
        display: flex;
        align-items: center;
    }
    .operation .sex .ys-radio-group .ys-radio{
        margin: 0 5px;
    }
    /* 实现光晕效果 */
    .ys-radio.active:before{
        content: '';
        display: inline-block;
        border-radius: 50%;
        position: absolute;
        animation: ys-radio-animate .2s linear;
    }
    @keyframes ys-radio-animate {
        from{
            width: 0;
            height: 0;
        }
        to{
            width: 24px;
            height: 24px;
        }
    }

     ys-Model_antDesign.js

    /**
    * 功能:自定义插件的js文档
    * 作者:一乐
    * 时间:2021/7/30
    * 地点:一乐乐家园
    */
    
    /***
     * 自定义的单选框的激活效果的构建
     */
    function ysRadioInit(){
        //获取单选框组合
        let ys_radio_group = document.querySelectorAll('.ys-radio-group');
        //遍历单选框组合
        ys_radio_group.forEach(function (value,index) {
            if(value.getAttribute('data-ysRadioInit') === 'true') return;
            //获取单选框组合的内容
            let ys_radios = value.querySelectorAll('.ys-radio');
            //遍历获取每个单选框,并为之添加事件~实现点击激活的效果
            ys_radios.forEach(function (value2,index) {
                value2.addEventListener('click',function (e) {
                    //去除已经选择的单选框样式
                    ys_radios.forEach(function (value3,index) {
                        value3.classList.remove('active');
                    });
                    value2.classList.add('active');
                });
    
                //为单选框添加文本
                let ys_radio_txt = value2.getAttribute('data-show');
                let span = document.createElement('span');
                //span内置文本
                span.innerText = ys_radio_txt;
                //将span添加到单选框后边
                value.insertBefore(span,value2.nextElementSibling);
    
                //为元素添加一个标记属性,标记是否已经初始化
                value.setAttribute('data-ysRadioInit','true');
            });
        });
    }

    Model_antDesign.js

    window.onload= function (){
        //初始化单选框
        ysRadioInit();
        //设置定期循环刷新
        setTimeout(ysRadioInit,3000);
    }

    3,思路~过程:

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

     

  • 相关阅读:
    SpringBoot整合SpringDataJPA,今天没啥事情就看了一下springboot整合springdataJPA,实在是香啊,SQL语句都不用写了
    SpringMVC+Spring+Mybatis整合
    开源的分布式事务框架 springcloud Alibaba Seata 的搭建使用 一次把坑踩完。。。
    spring cloud Alibaba --sentinel组件的使用
    springcloud整合config组件
    springcloud整合geteway网关服务
    springcloud组件之hystrix服务熔断,降级,限流
    干货 springcloud之 poenFeign的使用
    springcloud组件之注册中心eureka学习
    面试题---->线程的入门,读完可以应付一般的面试(管理员不要移除我的随笔啊)
  • 原文地址:https://www.cnblogs.com/shan333/p/15077998.html
Copyright © 2020-2023  润新知