【前端】使用jQuery封装一套UI组件 - 可编辑下拉框组件

简介: 下拉框也是比较常用的组件,对应原生的下拉标签就是select本篇文章就来讲讲可编辑下拉框组件的封装过程
作者:小5聊基础
简介:一只喜欢全栈方向的程序员,欢迎咨询,尽绵薄之力答疑解惑
编程原则:Write Less Do More

【静态布局】

1)组件整体设计 <br/>
组件框架、左边为输入文本框、右边为箭头图标、隐藏区域的下拉列表值 <br/>
2)先设置一个组件框架div,设置宽度为230px,高度为30px <br/>
3)框架内,左边设置一个div,左浮动,宽度为200px,高度和行高为30px <br/>
浮动的div内设置一个input标签,用于输入信息 <br/>
4)框架内,右边设置一个div,同样是左浮动,高宽度均为30px <br/>
浮动的div内设置一个span标签,用于设置图标 <br/>
5)设置箭头向下图标 <br/>
border: 8px solid transparent;border-top-color:#ccc;
6)设置箭头向上图标 <br/>
在箭头向下的基础上,设置旋转180度样式可得到箭头向上箭头
transform:rotate(180deg);

  • 效果

image.png

  • 代码
<style type="text/css">
    .arrow-down {
        display: inline-block;
        background-color: transparent;
        width: 0px;
        font-weight: bold;
        border: 8px solid transparent;
        border-top-color: #ccc;
        margin: 10px 0 0 6px;
    }
</style>
<div class="" style="width:230px;height:30px;border:1px solid #ccc;">
    <div style="width:200px;height:30px;line-height:30px;float:left;">
        <input placeholder="请选择" style="float:none;margin-left:0px;width:90%;padding-left:5%;" />
    </div>
    <div style="width:30px;height:30px;float:left;">
        <span class="arrow-down"></span>
    </div>
</div>

【隐藏区域的下拉框】

1)框架内,设置一个下拉框的父级div,宽度设置为230px,高度为200px,超出高度则显示滚动条 <br/>
2)设置选项区域,div标签包含span标签
div标签设置高度和行高为35px,并设置手指样式,以及hover高亮样式,span标签则显示对应的文本值 <br/>

  • 效果

image.png

【箭头图标分析】

1)设置一个目标样式的宽度为0,并转为块和行内元素display:inline-block <br/>
2)设置边框为8px,可以根据自己情况设定,默认透明 <br/>
border: 8px solid transparent; <br/>
3)可以分别设置边框四个方向的颜色 <br/>
border-top-color、border-right-color、border-bottom-color、border-left-color
image.png

<div style="width:0;display:inline-block;border:80px solid transparent;border-top-color:#099dff;border-right-color:#f38237;border-bottom-color:#db85ea;border-left-color:#5cd5e9;">
</div>

【交互设置】

1)绑定文本框和箭头点击事件 <br/>
点击文本框,箭头由向下变为向上,同时显示下拉文本框,可以设置flag标志来回切换 <br/>
这里有个小技巧,当点击其他地方时,也就是document,也要隐藏下拉,但是点击箭头和文本框都会触发document点击事件,所以,可以在文本框点击事件里加一个事件冒泡 <br/>
2)下拉框选项模板 <br/>

<script type="text/template" id="selectTemplate">
    <div class="select-item">
        <span></span>
    </div>
</script>

3)页面加载时,循环下拉选项值 <br/>
获取模板html,然后清空前后空格转为dom对象,给虚拟dom对象赋值,最后通过获取完整html追加到目标下拉div里

  • 效果

image.png

  • 代码
var selectArr = ['语文', '数学', '英语', '物理', '化学', '生物', '历史', '地理', '政治'];
function createSelect() {
    var template = $("#selectTemplate").html().trim();
    var html = '';
    for (var i = 0; i < selectArr.length; i++) {
        var dom = $(template);
        $("span", dom).html(selectArr[i]);
        html += dom.prop('outerHTML');
    }
    $(".select-list-div").html(html);
}
createSelect();

4)设置下拉选项的点击事件 <br/>
同时也设置防止冒泡,子元素和父元素同时设置点击事件时,先会从内到外逐个触发事件,可以给子级设置防止冒泡来阻断父级事件得触发
5)

【主要知识点列表】

编号 语言或插件 知识点 说明
1 css transition 过渡、渐变属性,transition:all .5s
2 css transform 转变属性,一般结合旋转、放缩、坐标轴等,transform:rorate(180deg),旋转180度
3 js event 事件对象,var event = event window.event;
4 js stopPropagation 阻止事件冒泡,var event = event window.event;

【完整代码】

<style type="text/css">
    .select-div {
        width: 230px;
        height: 30px;
        border: 1px solid #ccc;
        position: relative;
        border-radius: 5px;
    }

    .arrow-span {
        transition: all .5s;
        -moz-transition: all .5s; /* Firefox 4 */
        -webkit-transition: all .5s; /* Safari 和 Chrome */
        -o-transition: all .5s; /* Opera */
    }

    .arrow-down {
        display: inline-block;
        width: 0px;
        border: 8px solid transparent;
        border-top-color: #ccc;
        margin: 10px 0 0 6px;
    }

    .arrow-up {
        display: inline-block;
        width: 0px;
        border: 8px solid transparent;
        border-top-color: #ccc;
        transform: rotate(180deg);
        margin: 2px 0 0 6px;
    }

    .select-list-div {
        width: 230px;
        height: 200px;
        position: absolute;
        top: 35px;
        left: 0px;
        border-radius: 5px;
        box-shadow: 0 0 13px #ccc;
        background: #fff;
        overflow:auto;
    }

    .select-item {
        width: 100%;
        height: 40px;
        line-height: 40px;
    }

        .select-item span {
            margin-left: 30px;
        }

        .select-item:hover, .select-item-action {
            background: #f3f3f3;
        }
</style>
<div class="select-div">
    <div style="width:200px;height:30px;line-height:30px;float:left;">
        <input id="btnMajor" placeholder="请选择" style="float:none;margin-left:0px;width:90%;padding-left:5%;" />
    </div>
    <div class="arrow-div" style="width:30px;height:30px;float:left;">
        <span class="arrow-span arrow-down"></span>
    </div>
    <!--下拉框列表-->
    <div class="select-list-div" style="display:none;"></div>
</div>

<!--下拉选项模板-->
<script type="text/template" id="selectTemplate">
    <div class="select-item">
        <span></span>
    </div>
</script>

<script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
<script type="text/javascript">

    $(function () {
    // 文本框点击事件
        $("#btnMajor,.arrow-div").click(function (event) {
            var flag = $(".select-div").attr('data-flag');
            if (flag == '1') {
                $(".select-list-div").hide();
                $(".arrow-span").removeClass('arrow-up');
                $(".select-div").attr('data-flag', '0');
            }
            else {
                $(".select-list-div").show();
                $(".arrow-span").addClass('arrow-up');
                $(".select-div").attr('data-flag', '1');
            }

            event.stopPropagation();
        });
        $(document).click(function () {
            $("#btnMajor").trigger('click');
        });

        // 循环遍历下拉选项值
        var selectArr = ['语文', '数学', '英语', '物理', '化学', '生物', '历史', '地理', '政治'];
        function createSelect() {
            var template = $("#selectTemplate").html().trim();
            var html = '';
            for (var i = 0; i < selectArr.length; i++) {
                var dom = $(template);
                $("span", dom).html(selectArr[i]);
                html += dom.prop('outerHTML');
            }
            $(".select-list-div").html(html);
        }
        createSelect();

        // 选项点击事件
        $(".select-item").click(function (event) {

            event.stopPropagation();
        });
    });
</script>
相关文章
|
9天前
|
JavaScript
超炫酷UI效果的jQuery滑块插件
超炫酷UI效果的jQuery滑块插件
23 0
|
1月前
|
存储 前端开发 搜索推荐
(前端直接编辑CAD)网页CAD二次开发中线型表的使用方法
在DWG数据库中,线型样式存储在线型样式表 `McDbLinetypeTable` 中,每个线型表记录对象 `McDbLinetypeTableRecord` 对应一种线型样式。本文介绍了如何获取、添加、遍历、删除和修改线型样式,并提供了绘制不同线型的示例代码,包括虚线、点划线和带文字的线型。通过在线示例demo,用户可以实践修改CAD图纸中的实体线型及其样式。
|
1月前
|
JSON 缓存 前端开发
个人练习前端技术使用Bootstrap、JQuery、thymeleaf
个人练习前端技术使用Bootstrap、JQuery、thymeleaf
35 3
|
3月前
|
前端开发 API
(WEB前端编辑DWG)在线CAD如何实现图形识别功能
mxcad 提供的图形识别功能可帮助用户快速识别和提取 CAD 图纸中的各种图形,如直线、多段线、弧线、圆及图块,显著提升设计效率。此功能不仅适用于图形分类,还能进行数量统计和快速定位,减少手动操作。用户可通过 API 进行二次开发,自定义识别逻辑。具体步骤包括打开在线示例、选择识别功能、设置识别参数并开始识别。更多开发文档请关注公众号:梦想云图网页 CAD。
|
3月前
|
JSON 缓存 前端开发
个人练习前端技术使用Bootstrap、JQuery、thymeleaf
个人练习前端技术使用Bootstrap、JQuery、thymeleaf
30 2
|
3月前
|
JSON JavaScript 前端开发
jQuery下拉框搜索模糊查询实现
【9月更文挑战4天】
123 10
|
2月前
|
JavaScript 前端开发 API
【前端基础篇】JavaScript之jQuery介绍
【前端基础篇】JavaScript之jQuery介绍
92 0
|
4月前
|
缓存 前端开发 Java
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
【8月更文挑战第10天】java基础巩固,工具类的封装
29 1
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
|
4月前
|
JavaScript 前端开发 程序员
后端程序员的前端必备-jQuery核心学习笔记
后端程序员的前端必备-jQuery核心学习笔记
63 13
|
4月前
|
JavaScript
H-ui JQuery 给单选按纽赋值不生效
H-ui JQuery 给单选按纽赋值不生效
40 0
H-ui JQuery 给单选按纽赋值不生效