【前端】使用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>
相关文章
|
28天前
|
前端开发 API
(WEB前端编辑DWG)在线CAD如何实现图形识别功能
mxcad 提供的图形识别功能可帮助用户快速识别和提取 CAD 图纸中的各种图形,如直线、多段线、弧线、圆及图块,显著提升设计效率。此功能不仅适用于图形分类,还能进行数量统计和快速定位,减少手动操作。用户可通过 API 进行二次开发,自定义识别逻辑。具体步骤包括打开在线示例、选择识别功能、设置识别参数并开始识别。更多开发文档请关注公众号:梦想云图网页 CAD。
|
5天前
|
JavaScript 索引
Vue开发中Element UI/Plus使用指南:常见问题(如Missing required prop: “value“)及中文全局组件配置解决方案
Vue开发中Element UI/Plus使用指南:常见问题(如Missing required prop: “value“)及中文全局组件配置解决方案
32 0
|
16天前
Element-UI组件的使用
【10月更文挑战第1天】
28 0
|
1月前
|
JavaScript
从零开始写一套广告组件【一】搭建基础框架并配置UI组件库
其实这个从零有点歧义,因为本质上是要基于`tdesign-vue-next`来进行二次封装为一套广告UI组件库,现在让我们在一起快乐的搭建自己的广告UI库之前,先对以下内容做出共识:
61 0
从零开始写一套广告组件【一】搭建基础框架并配置UI组件库
|
1月前
|
JSON JavaScript 前端开发
|
2月前
|
存储 搜索推荐 Java
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!
|
2月前
|
JavaScript 前端开发 安全
[译] 在 Vue 组件中分离 UI 和业务逻辑。
[译] 在 Vue 组件中分离 UI 和业务逻辑。
|
2月前
|
JavaScript UED
基于Vue2.0仿Element UI的el-tooltip实现一个气泡框组件,支持多数据类型的显示和内容为空时不显示气泡框
该文章介绍了如何基于Vue2.0仿照Element UI的el-tooltip组件实现一个自定义的气泡框组件,该组件能够根据内容是否为空智能显示或隐藏,支持多种数据类型的显示。
100 0
基于Vue2.0仿Element UI的el-tooltip实现一个气泡框组件,支持多数据类型的显示和内容为空时不显示气泡框
|
2月前
|
开发框架 JSON 缓存
基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理
基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理
|
2月前
|
数据可视化 数据挖掘 持续交付
Axure Web端元件库:从Quick UI到500+组件的飞跃
在快速变化的数字世界中,产品设计不仅仅是功能的堆砌,更是用户体验的精心雕琢。原型设计作为产品开发过程中的关键环节,其重要性不言而喻。Axure,作为业界领先的原型设计工具,凭借其强大的交互设计和丰富的功能,赢得了全球设计师和开发者的信赖。而Axure Web端元件库,则是这一平台上的一颗璀璨明珠,它以超过500个精心设计的组件为基础,为设计师们打开了一扇通往高效、高质量原型设计的大门。
100 0