select表单元素详解及下拉列表模拟实现

图书馆前
图书馆前

原文地址:→看过来

写在前面

select 是HTML表单元素中很常用的一个,其中很重要的几个属性常被忽略,但这几个属性却能帮助我们完成很多的功能,当然,select下拉列表默认样式很不友好,所以更多的时候可以自己模拟实现一个同样功能的下拉菜单。下文先介绍select标签的一些属性及使用,后面再模拟一个相同效果的下拉菜单。

介绍之前先看下demo预览图:

  1. firefox下select的默认样式:


    firefox-default
  2. chrome下select的默认样式:


    chrome-default
  3. firefox下自定义select下拉列表的icon效果:


    firefox-self
  4. chrome下自定义select下拉列表的icon效果:


    chrome-self
  5. 原生js模拟select下拉列表的实现效果(chrome及firefox效果一致):


    模拟select

源代码地址→传送门

预览地址→传送门

1. select表单元素及相关属性(我只是大自然的搬运工)

  • 提示
    select 元素是一种表单控件,可用于在表单中接受用户输入

  • 支持的全局属性

    • 仅挑几个属性
    • autofocus(其值为autofocus): 规定在页面加载后文本区域自动获得焦点。
    • disabled(值为disabled): 规定禁用该下拉列表。
    • form(值为form_id): 规定文本区域所属的一个或多个表单。
    • multiple(值为multiple): 规定可选择多个选项。
  • 支持的事件属性

    • 挑一个最常用到的额
    • onchange:当select改变选择时调用的事件句柄。(可以实现三级联动的效果)
  • selected对象的属性及方法

    • 挑几个重要的额
    • options[]:返回包含下拉列表中的所有选项的一个数组。
    • length:返回下拉列表中的选项数目。
    • selectIndex:设置或返回下拉列表中被选项目的索引号。
    • add(): 向下拉列表添加一个选项。
    • remove(): 从下拉列表中删除一个选项。
  • option标签

    • option元素定义下拉列表中的一个选项(一个条目)。
    • disabled(值为disabled):规定此选项应在首次加载时被禁用。
    • label(值为text):定义当使用 <optgroup> 时所使用的标注。
    • selected)(值为selected):规定选项(在首次显示在列表中时)表现为选中状态。
    • value(text): 定义送往服务器的选项值。
  • option对象的属性

    • 几个比较重要的额
    • defaultSelected:返回 selected 属性的默认值。
    • disabled:设置或返回选项是否应被禁用。
    • index:返回下拉列表中某个选项的索引位置。
    • selected:设置或返回 selected 属性的值。

注意

  1. select本身的样式可用css设置,但对option设置的样式在chrome中不起作用,在Firefox可行
  2. w3c官网的详细解释 → 传送门

2. HTML标签自定义属性(纯属题外话)

HTML5 data-*自定义属性:添加data-前缀使属性变成自定义属性,最大的好处是我们可以把所有自定义属性在dataset对象中统一管理。

<div id="student" data-weight="98">点击显示</div>

var student = document.getElementById("student");
student.dataset.cm = '168'; //设置自定义属性
var stuWeight = studdent.dataset.weight; //获取自定义属性值

student.dataset.birthDate = '19980612';  //连字符的自定义属性 (例如设置data-birth-date)

3. 自定义下拉列表的图标

select默认样式中的下拉按钮不是很好看,我们可以自己用替张图片替换掉。(效果看文章上面的链接,请忽略我的丑丑的图标额)

  1. 对select自定义图标时需要设置apperance属性为none(隐藏原有小三角),并做兼容
  2. 加上将要替换的自定义图标即可
select{
    -webkit-appearance: none; /*隐藏默认样式中的小三角*/
    -moz-appearance: none;
    background: url('http://opif0c56u.bkt.clouddn.com/select.gif') no-repeat scroll right 8px center; 
}
  1. 可对option添加背景色
  2. 在firefox中可使用伪元素:before对option添加序号(此处插播一个css添加序号的方法)
select{
    counter-reset: item; //类似于声明计数变量(声明在父元素中)
}
select option:before {
    counter-increment: item;   //要使用的计数名
    content: counter(item) " . "; //追加前置序号,chrome对option的设置中不起作用
}

4. js模拟select下拉菜单(重头戏)

许多时候会觉得select表单特别的不好用,不能自己添加很多的样式,小伙伴们还是自己模拟一个吧!

  1. html代码结构:
<div id="sel-wrap">
    <div id="sel-show">=请选择=</div>
    <ul id="sel-option">
        <li class="item">早上吃包子</li>
        <li class="item">中午吃米饭</li>
        <li class="item">晚上吃面条</li>
        <li class="item">宵夜吃烧烤</li>
        <li class="item">睡前喝牛奶</li>
    </ul>
</div>
  1. 下拉按钮的图标跟上面自定义的方式一致(这里不再说了)。

  2. hover到li上时,利用伪元素:before追加一个对勾。

#sel-option li:hover:before {
    content: '\2714' ' ';  //此处为对勾+空格
    }
  1. 下面说下实现原理:
    • 下拉菜单的选项为ul中的内容,需要先隐藏起来,且显示的时候是浮在其他内容的上面,此处需要使用position来实现。(即脱离文档流)
#sel-wrap{
    position: relative;  //设置父元素
}
#sel-option{
    position: absolute;  //设置下拉列项的包裹层
}
  • 点击下拉框时显示下拉列表项
var flag = false;    //初始化一个flag标记
selShow.onclick = function () {
        flag = !flag;
        if (flag == true) {
            selOption.style.display = 'block';
        } else {
            selOption.style.display = 'none';
        }
    };
  • 点击列表项时将选中值传递给下拉框并显示,同时下拉项收起(此处的点击事件绑定在父元素中)
  selOption.onclick = function (e) {
        var ev = e || window.event;
        var target = ev.target || ev.srcElement;
        if (target && target.nodeName == 'LI') {
            selShow.innerText = target.innerText;
            selOption.style.display = 'none';
            flag = false;
        }
    };
  • 当下拉项显示并未选中任何下拉项时,点击下拉框收起下拉项

  • 当下拉项显示并未选中任何下拉项时,点击下拉项以外的任意位置,收起下拉框(将事件绑定在body上)

bd.onclick = function (ev) {
      var e = ev || event;
      var target = e.target || e.srcElement;
      if (target && target.id != 'sel-option' && target.id != 'sel-show' && target.className != 'item') {
       selOption.style.display = 'none';
            flag = false;
        } else {
            return false;
        }

        if (e && e.stopPropagation) {//阻止冒泡
            e.stopPropagation();
        } else {
            window.event.cancelBubble = true;
        }
    };

  • 最终实现(样式什么的都可以随便改):
最终样式

小结

  1. 小花作为菜鸟第一次自己模拟下拉列表的实现,有可能存在代码欠缺,但是为了方便以后使用的时候查询,所以就记录下
  2. 欢迎大佬们指点
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,585评论 18 139
  • 有位姑娘咨询欧巴,说自己想去韩国结婚,不知道这种情况应该申请什么签证,这个是分两种情况的,主要看您是否要在韩国长期...
    汉纸心的小驴人阅读 1,365评论 0 0
  • 自定义flowlayout实现分页 collectionView 分页 & 偏移位置 collectionView...
    xiari1991阅读 323评论 0 0
  • 马拉松比赛里的兔子,其实说的是领跑员,按照一定的配速,在指定时间前后两分钟内跑完全程才能算是合格。因为在比赛中,领...
    白大炮阅读 373评论 0 0