当前位置: 移动技术网 > IT编程>开发语言>JavaScript > select标记美化--JS式插件、后期加载

select标记美化--JS式插件、后期加载

2019年07月19日  | 移动技术网IT编程  | 我要评论

<select>标签的外观问题很恼人,各个浏览器都不一致,单单就ie,一个版本就一个长相,还不能用css修饰。

在这将本人对<select>的美化方法共享出来。
优点: 仍保留使用<select>,仅改变外观,不改变不干预form行为,后期加载js。(注:本脚本依赖jquery)

啥也不说了,都在代码里。
效果图在底部。


$(document).ready(function () {

    // 找出需要美化的<select>标记,我们用一个class名称 "beautify" 来确定,没有这个样式的<select>则将被忽略
    var selects = $("select.beautify");
    if (selects.length > 0) {

        //先在代码底部增加一个<div>,用来承载和显示下拉框选项
        $("body").append("<div id='dummydata' style='position:absolute; display:none'></div>");

        //挨个美化呗
        selects.each(function () {

            //给本函数下的 this (也就是 <select>) 设置一个别名,在下面的匿名函数中将会被用到
            var select = this;

            //创建一个 <input> ,  .dummy 将用于我们对此类 <input> 进行专门样式定义
            //同时将 <select> 的部分属性和样式复制给这个 dummy input
            //创建完后,将这个 <input> 插入 dom, 紧跟原 <select>
            var input = $("<input type='text' readonly='readonly' class='input dummy' />")
                .attr("disabled", this.disabled)
                .css("width", parseint(this.style.width) + "px")
                .css("display", this.style.display)
                .insertafter(this)
                .val(this.options[this.selectedindex].text);

            //将 <select> 藏掉,不要在 .beautify 中去定义 display:none, 因为js加载失败时,我们还得用上它
            this.style.display = "none";

            // 当 <input class='dummy'> 被点击时
            input.click(function () {
                //调出前面创建的 <div id='dummydata'>,并清空内容
                //将 <select> 的样式表传递给它,当需要对这个 <div> 进行修饰时,就靠这些样式定义
                var div = $("#dummydata")
                    .empty()
                    .attr("class", select.classname);

                //设置 <div> 的宽度
                //在这里我们判断一个特殊的class名 "extend"
                //如果带有 .extend,表示宽度将受额外自定义控制;否则,宽度将默认与 <input> 一致
                $(select).hasclass("extend")
                    ? div.css("width", "")
                    : div.css("width", $(this).innerwidth());

                //将 <option> 复制到 <div id='dummydata'> 里面,一个 <option> 对应一个 <a> 标记
                for (var i = 0; i < select.options.length; i++) {
                    var item = select.options[i];
                    var a = $("<a href='javascript:void(0);' class='nowrap'></a>")
                        .css("color", item.style.color)
                        .addclass(item.classname)
                        .html(item.text)
                        .appendto(div);
                    if (i == select.selectedindex) {
                        a.addclass("selected");
                    }
                    //当选项被点击时,<input> 内容显示为对应 <option>,关闭 <div> 层,同时将事件冒泡给原来的 <select>
                    a.click(function () {
                        var n = $(this).index();
                        select.selectedindex = n;
                        input.val(select.options[n].text);
                        div.hide();
                        $(select).change();
                    });
                }

                //在这里我们判断一个特殊的class名 "noscroll"
                //当选项过多时,默认会让选项列表出现滚动条;但如果有 .noscroll 修饰,则强制不出现滚动条
                var noscroll = (select.options.length < 10 || $(select).hasclass("noscroll"));
                if (/msie 6/i.test(window.navigator.useragent)) {
                    div.css("height", noscroll ? "auto" : "215px").css("overflow-y", noscroll ? "hidden" : "scroll");
                } else {
                    div.css("max-height", noscroll ? "10000px" : "215px");
                }

                //在这里我们判断一个特殊的class名 "onside"
                //如果有 .onside 修饰,弹出的选项层将在侧面,否则是在下面
                //注: 此处用到2个函数 locatebeside 和 locatebelow 是本人js库中的方法,稍等另外给出
                $(select).hasclass("onside")
                    ? div.locatebeside(this, -2)
                    : div.locatebelow(this, -4);

                //对反复点击 <input> 之类的事情,做一些智能调节
                if (window.activedummyselect == select) {
                    div.slidetoggle(100);
                } else {
                    div.hide().slidedown(100);
                    window.activedummyselect = select;
                }

                //在有滚动条的情况下,我们需要将滚动条滚动到当前选中项的位置
                if (!select.selectedindex > 6 && div[0].scrollheight > div.height()) {
                    div.scrolltop((select.selectedindex - 3) * div[0].firstchild.offsetheight);
                }
            });
        });

        //最后别忘了:点击网页上的游离区域时,应该隐藏<div #dummydata>
        $(document).click(function (e) {
            if (!$(e.target).is(".dummy") && !$(e.target).is("#dummydata")) {
                $("#dummydata").hide();
            }
        });
    }
});

上面代码里说用到了2个方法: locatebeside 和 locatebelow, 是本人js库中对 jquery 的扩展,顺便多赠送2个方法 locate 和 locatecenter
:-)  代码如下:

 

上面样式定义的效果图

 

html中要做的,只是加几个class修饰

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网