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

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

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


1,效果:

6.png 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;
    /*width: 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);
}
目录
相关文章
|
5月前
|
移动开发 前端开发 JavaScript
征信报告修改器,征信报告生成器,制作软件无痕修改软件【js+html+css】
本项目为信用评分模拟器教学工具,采用HTML5实现,仅供学习参考。核心功能通过JavaScript构建,包含虚拟数据生成、权重分配及信用因素分析(如还款记录、信用使用率等)。
|
5月前
|
前端开发 JavaScript
个人征信电子版无痕修改, 个人信用报告pdf修改,js+html+css即可实现【仅供学习用途】
本代码展示了一个信用知识学习系统的前端实现,包含评分计算、因素分析和建议生成功能。所有数据均为模拟生成
|
5月前
|
存储 前端开发 JavaScript
仿真银行app下载安装, 银行卡虚拟余额制作app,用html+css+js实现逼真娱乐工具
这是一个简单的银行账户模拟器项目,用于学习前端开发基础。用户可进行存款、取款操作,所有数据存储于浏览器内存中
|
5月前
|
前端开发
个人征信PDF无痕修改软件,个人征信模板可编辑,个人征信报告p图神器【js+html+css仅供学习用途】
这是一款信用知识学习系统,旨在帮助用户了解征信基本概念、信用评分计算原理及信用行为影响。系统通过模拟数据生成信用报告,涵盖还款记录
|
5月前
|
前端开发 JavaScript 容器
制作b超单生成器, 假怀孕b超单图片制作, p图医院证明【css+html+js装逼恶搞神器】
本资源提供一个适合用于熟人之间恶搞的工具,效果逼真,仅供学习参考与娱乐。包含前端技术学习要点:语义化布局、响应式设计、Flexbox、图片自适应
|
5月前
|
前端开发
医院检查单子p图软件,在线制作仿真病历,js+css+html装逼神器
本示例展示如何用HTML/CSS创建医疗信息页面,内容仅供学习参考。页面模拟“阳光医院体检中心”场景,提供预约功能验证(如姓名、手机号、日期)。所有数据仅用于演示
|
5月前
|
存储 前端开发 安全
病历单生成器在线制作,病历单生成器app,HTML+CSS+JS恶搞工具
本项目为医疗病历模拟生成器,旨在为医学教学和软件开发测试提供数据支持,严格遵守《医疗机构病历管理规定》。
|
10月前
|
人工智能 程序员 UED
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
471 21
【01】完成新年倒计时页面-蛇年新年快乐倒计时领取礼物放烟花html代码优雅草科技央千澈写采用html5+div+CSS+JavaScript-优雅草卓伊凡-做一条关于新年的代码分享给你们-为了C站的分拼一下子
|
9月前
|
前端开发
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布
269 1
【2025优雅草开源计划进行中01】-针对web前端开发初学者使用-优雅草科技官网-纯静态页面html+css+JavaScript可直接下载使用-开源-首页为优雅草吴银满工程师原创-优雅草卓伊凡发布