jquery封装的时间轴

概述

很多时候,都会用到类似于时间轴的东西,鉴于网络资源没有那么顺手,就想着自己搞一个,在此将源码贴出来。


效果

jquery封装的时间轴_第1张图片

代码

样式文件style.css

.timeline{
    position: absolute;
    z-index: 5000;
    font-size: 12px;
    border: 1px solid #ccc;
    background: whitesmoke;
    background: -webkit-linear-gradient(top, whitesmoke, #ddd);
    background: -ms-linear-gradient(top, whitesmoke, #ddd);
    background: -moz-linear-gradient(top, whitesmoke, #ddd);
    border-radius: 4px 0 4px 0;
    box-shadow: 0px 0px 10px rgba(150,150,150,0.5);
}
.timeline ul.ulvec{
    margin-left: 10px;
    list-style: none;
    background: url("dot.gif") 0px 0px repeat-y;
    padding-right: 10px;
}
.timeline ul li.livec{
    margin-left: -43px;
    padding: 0px 0px 0px 12px;
    background: url("biggerdot.png") 0px 50% no-repeat;
    cursor: pointer;
}
.timeline ul.ulhor{
    margin: 0px;
    padding: 5px 10px;
    list-style: none;
    background: url("dot.gif") 0px 5px repeat-x;
}
.timeline ul li.lihor{
    display: inline-block;
    margin: 0px;
    padding: 10px 0px 0px 0px;
    margin-top: -3px;
    background: url("biggerdot.png") 50% 0px no-repeat;
    cursor: pointer;
}
.timeline ul li span{
    display: block;
    padding: 4px 15px;
    border: 1px solid transparent;
}
.timeline ul li.active span{
    color: #f2f2f2;
    box-shadow: inset 0px 0px 30px #333333;
    border-radius: 4px;
    border: 1px solid #ffffff;
    background: #666;
}


控件代码 jquery.custom.timeline.js

(function($){
    $.fn.TimeLine = function(options){
        var defaults = {
            data:null,
            vertical:false
        };

        var options = $.extend(defaults,options);
        var _data = options.data;
        var _vertical = options.vertical;
        var _showDiv = $(this).addClass("timeline");
        var _ul = $("<ul />").appendTo(_showDiv);
        if(_vertical){
            _ul.addClass("ulvec");
        }
        else{
            _ul.addClass("ulhor");
        }
        for(var i= 0,dl=_data.length;i<dl;i++){
            var _li = $("<li />").appendTo(_ul);
            if(_vertical){
                _li.addClass("livec");
            }
            else{
                _li.addClass("lihor");
            }
            var _span = $("<span />").attr("value",_data[i].value).html(_data[i].label).appendTo(_li);
            _span.on("click",function(){
                var _value = this.getAttribute("value");
                active(_value);
            });
        }
        function active(value){
            $("li").removeClass("active");
            var _spans = $("ul").find("span");
            for(var i= 0,dl=_spans.length;i<dl;i++){
                var _span = _spans[i];
                if(_span.getAttribute("value")===value){
                    var _li = $(_span.parentNode);
                    _li.addClass("active");
                }
            }
        }
        this.active = active;
        return this;
    }
})(jQuery);

调用实现

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <link rel="stylesheet" href="style.css" type="text/css">
    <script src="http://localhost/jquery/jquery-1.8.3.js"></script>
    <script src="jquery.custom.timeline.js"></script>
    <script>
        var data = [{"label":"2011年","value":"2011"},
            {"label":"2012年","value":"2012"},
            {"label":"2013年","value":"2013"}
        ];
        $(function(){
            var timelinehor = $("#timelinehor").TimeLine({
                data:data,
                vertical:false
            });
            timelinehor.active(data[0].value);
            var timelinevec = $("#timelinevec").TimeLine({
                data:data,
                vertical:true
            });
            timelinevec.active(data[0].value);
        });
    </script>
</head>
<body>
<div id="timelinehor"></div><br><br><br>
<div id="timelinevec"></div>
</body>
</html>





你可能感兴趣的:(jquery,控件,时间轴)