zoukankan      html  css  js  c++  java
  • div自定义下拉框组件

    因为原生的下拉框不能修改其属性,很难美化下拉框。

    所以自己用div简单自定义了一下下拉框,想美化直接修改css即可

    <!DOCTYPE html>
    <html lang="zh-cn">
    <head>
    <meta charset="UTF-8">
    <title>div模仿下拉框</title>
    <style>
    *{
        padding: 0;
        margin: 0;
    }
    .select-box{
        width: 200px;
        margin: 50px auto;
        text-align: left;
        text-indent: 5px;
        /* border: 1px solid #ccc; */
        padding: 10px;
    }
    .select-box .select-title{
        height: 30px;
        line-height: 30px;
        display: block;
        margin-bottom: 10px;
        border: 1px solid #ccc;
        padding: 5px 10px;
        cursor:pointer;
    }
    .select-box ul{
        border: 1px solid #ccc;
    }
    .select-box ul li{
        height: 30px;
        line-height: 30px;
        list-style: none;
        padding: 5px 10px;
        cursor: pointer;
    }
    .select-box ul li.current{
        background: #ebebeb;
    }
    .select-box ul li:not(:last-of-type){
        border-bottom: 1px solid #ccc;
    }
    .none{
        display: none;
    }
    .block{
        display: block;
    }
    </style>
    </head>
    <body>
        <div class="select-box">
            <span class="select-title">web前端</span><!-- 下拉标题 -->
            <ul class="select-con none">
                <li>web前端</li>
                <li>php</li>
                <li>java</li>
                <li>ios</li>
                <li>安卓</li>
            </ul>
        </div>
    <script src="jquery-3.0.0.min.js"></script>    
    <script>
        $(document).bind("click",function(e){
            var clickMe=$(e.target);/*获取点击元素*/

          if(!clickMe.hasClass("select-title")){/*点击元素不是下拉框标题时*/
            $(".select-box ul").addClass("none").removeClass("block");
            if(clickMe.parent().hasClass("select-con")){/*点击元素是下拉选项时*/
              var currenLiHtml=clickMe.html();/*获取点击的下拉选项HTML*/
              clickMe.parent().siblings(".select-title").html(currenLiHtml);/*把点击的下拉选项HTML放到下拉标题*/
              clickMe.addClass("current").siblings().removeClass("current");/*给点击的下拉选项加背景色*/
            }
          }else if(clickMe.siblings(".select-con").hasClass("none")){/*点击下拉标题时如果有none类的话*/
            clickMe.parents("body").find(".select-con").addClass("none").removeClass("block");/*点击下拉标题时如果有none类的话,全部下拉关闭,然后在展开当前的下拉*/
            clickMe.siblings(".select-con").addClass("block").removeClass("none");

            }else if(clickMe.siblings(".select-con").hasClass("block")){/*点击下拉标题时如果有block类下拉是展开的话*/
            $(".select-box ul").addClass("none").removeClass("block");
        }

    
        })
    </script>
    </body>
    </html>
  • 相关阅读:
    5G名词术语
    什么是IPv6
    如何用SecureCRT 登录eNSP模拟器里的设备
    numpy-排序
    numpy-tile 数组复制
    经纬度计算距离与方位角
    numpy-添加操作大全
    高效编程之 concurrent.future
    linux命令 集合
    PostgreSQL-表空间
  • 原文地址:https://www.cnblogs.com/zzwlong/p/6076573.html
Copyright © 2011-2022 走看看