【前端】使用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>
相关文章
|
4月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
伪类:伪类这个叫法源自于它们跟类相似,但实际上并没有类会附加到标记中的标签上。 伪类分为两种(以及新增的伪类选择器): UI伪类:会在HTML元素处于某种状态时(例如:鼠标指针位于连接上),为该元素应用CSS样式。 :hover 结构化伪类:会在标记中存在某种结构上的关系时 例如: 某元素是一组元素中的第一个或最后一个,为该元素应用CSS样式。 :not和:target(CSS3新增的两个特殊的伪类选择器)
398 1
|
7月前
|
人工智能 JSON 前端开发
如何解决后端Agent和前端UI之间的交互问题?——解析AG-UI协议的神奇作用
三桥君指出AG-UI协议通过SSE技术实现智能体与前端UI的标准化交互,解决流式传输、实时进度显示、数据同步等开发痛点。其核心功能包括结构化事件流、多Agent任务交接和用户中断处理,具有"一次开发到处兼容"、"UI灵活可扩展"等优势。智能体专家三桥君认为协议将AI应用从聊天工具升级为实用软件,适用于代码生成、多步骤工作流等场景,显著提升开发效率和用户体验。
1796 0
|
JavaScript
超炫酷UI效果的jQuery滑块插件
超炫酷UI效果的jQuery滑块插件
151 0
|
缓存 前端开发 Java
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
【8月更文挑战第10天】java基础巩固,工具类的封装
128 1
【前端学java】java基础巩固复习巩固语法练习-工具类的封装(14)
|
前端开发 开发者 UED
前端只是切图仔?来学学给开发人看的UI设计
该文章针对前端开发者介绍了UI设计的基本原则与实践技巧,覆盖了布局、色彩理论、字体选择等方面的知识,并提供了设计工具和资源推荐,帮助开发者提升产品的视觉与交互体验。
|
前端开发 API
(WEB前端编辑DWG)在线CAD如何实现图形识别功能
mxcad 提供的图形识别功能可帮助用户快速识别和提取 CAD 图纸中的各种图形,如直线、多段线、弧线、圆及图块,显著提升设计效率。此功能不仅适用于图形分类,还能进行数量统计和快速定位,减少手动操作。用户可通过 API 进行二次开发,自定义识别逻辑。具体步骤包括打开在线示例、选择识别功能、设置识别参数并开始识别。更多开发文档请关注公众号:梦想云图网页 CAD。
|
JavaScript 前端开发 开发者
决战前端之巅!Element UI与Vuetify谁才是Vue.js组件界的霸主?一场关于颜值与实力的较量!
【8月更文挑战第30天】本文对比了两款热门的Vue.js组件库——Element UI与Vuetify。Element UI由饿了么团队打造,提供多种高质量UI组件,设计简洁大方。Vuetify基于Material Design规范,支持Vue.js 2.0及3.0版本,具备前瞻性。两者均涵盖表单、导航、数据展示等组件,Element UI配置选项丰富,而Vuetify则提供了更深层的样式定制功能。开发者可根据项目需求及个人偏好选择合适的组件库。
1364 0
|
JavaScript
H-ui JQuery 给单选按纽赋值不生效
H-ui JQuery 给单选按纽赋值不生效
168 0
H-ui JQuery 给单选按纽赋值不生效
|
开发框架 JSON 缓存
基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理
基于SqlSugar的开发框架循序渐进介绍(22)-- Vue3+TypeScript的前端工作流模块中实现统一的表单编辑和表单详情查看处理

热门文章

最新文章

  • 1
    前端如何存储数据:Cookie、LocalStorage 与 SessionStorage 全面解析
    807
  • 2
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(九):强势分析Animation动画各类参数;从播放时间、播放方式、播放次数、播放方向、播放状态等多个方面,完全了解CSS3 Animation
    365
  • 3
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
    287
  • 4
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
    253
  • 5
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
    372
  • 6
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(五):背景属性;float浮动和position定位;详细分析相对、绝对、固定三种定位方式;使用浮动并清除浮动副作用
    527
  • 7
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(四):元素盒子模型;详细分析边框属性、盒子外边距
    441
  • 8
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(三):元素继承关系、层叠样式规则、字体属性、文本属性;针对字体和文本作样式修改
    175
  • 9
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(二):CSS伪类:UI伪类、结构化伪类;通过伪类获得子元素的第n个元素;创建一个伪元素展示在页面中;获得最后一个元素;处理聚焦元素的样式
    398
  • 10
    【CSS】前端三大件之一,如何学好?从基本用法开始吧!(一):CSS发展史;CSS样式表的引入;CSS选择器使用,附带案例介绍
    324