码迷,mamicode.com
首页 > 其他好文 > 详细

滚动条

时间:2015-01-19 12:19:42      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:

/*
*oBox滚动条 oBtn滚动条滑块 oText滑动区域 oTxt文本区域 的 class或者id
*olong 滚动一次的距离
*/
(
    function($){
        $.fn.myScroll = function(options){
            var defaults = {    //oBox滚动条 oBtn滚动条滑块 oText滑动区域 oTxt文本区域
                oBox:‘right‘,
                oBtn:‘btn‘,
                oText:‘left‘,
                oTxt:‘in‘,
                olong:30
            }

            var obj = $.extend({},defaults,options),_this=$(this);

            //获取对象函数
            function getDom(dom){
                if($(‘.‘+dom)[0]){
                    $dom = _this.find(‘.‘+dom);
                }else{
                    $dom = _this.find(‘#‘+dom);
                };
                return $dom;
            }
            //获取对象
            obj.oBox = getDom(obj.oBox);
            obj.oBtn = getDom(obj.oBtn);
            obj.oText = getDom(obj.oText);
            obj.oTxt = getDom(obj.oTxt);
            //滚动条的最大行程
            var iMaxHeight = obj.oBox.outerHeight() - obj.oBtn.outerHeight();
            //滚动条的offsettop
            var iBoxTop = obj.oBox.offset().top;
            //文本内容与外容器的高的差值
            var iTxtHeight = obj.oText.outerHeight() - obj.oTxt.outerHeight();
            //滚动事件开关
            var dragging = false;

            obj.oBtn.mousedown(
                function (e){
                    //滚动事件开关打开
                    dragging = true;
                    disY = e.pageY - obj.oBtn.offset().top;
                    return false;
                }
            );

            $(‘html‘).mousemove(
                function (e){
                    if(dragging == true){
                        $(this).css(‘cursor‘,‘pointer‘);
                        var iTop;
                        //控制滑块跟随鼠标
                        iTop = e.pageY - disY - iBoxTop;
                        //控制滑块的范围
                        if(iTop<=0){iTop=0;}else if(iTop>=iMaxHeight){iTop=iMaxHeight;}
                        obj.oBtn.css(‘top‘,iTop);

                        //算出滑块行程与最大行程的百分比
                        var iScale = iTop / iMaxHeight;
                        //控制文本按滑块行程的百分比调整top值
                        obj.oTxt.css(‘top‘,iScale*iTxtHeight);

                        return false;
                    }
                }
            );

            $(‘html‘).mouseup(
                function(){
                    $(this).css(‘cursor‘,‘auto‘);
                    //滚动事件开关关闭
                    dragging = false;
                    return false;
                }
            );

            //注册滚动条事件

            //IE及其他浏览器注册滚轮
            obj.oBox[0].onmousewheel=obj.oText[0].onmousewheel=fnWheel;

            //火狐注册滚轮事件
            if(window.addEventListener){
                obj.oBox[0].addEventListener(‘DOMMouseScroll‘, fnWheel, false);
                obj.oText[0].addEventListener(‘DOMMouseScroll‘, fnWheel, false);
            }

            //定义fnWheel事件
            function fnWheel(e){
                var e = e || event ;
                var iBtn;    //鼠标向上或向下的判断属性
                var iTop;
                var iScale;

                if(e.wheelDelta){        //IE chrome
                    iBtn = e.wheelDelta > 0 ? true : false ;    //IE大于0为向上滚为true
                }else{
                    iBtn = e.detail < 0 ? true : false;            //FF小于0为向上滚为true
                }

                if(iBtn == true){
                    iTop = obj.oBtn.offset().top - iBoxTop - obj.olong;    //滑块向上移动obj.olong
                }else{
                    iTop = obj.oBtn.offset().top - iBoxTop + obj.olong;    //滑块向下移动obj.olong
                }
                if(iTop<=0){iTop=0;}else if(iTop>=iMaxHeight){iTop=iMaxHeight;}    //控制滑块范围

                obj.oBtn.css(‘top‘,iTop);    //控制鼠标滚动时滑块位置

                iScale = iTop / iMaxHeight ;    //算出滑块行程百分比
                obj.oTxt.css(‘top‘,iScale*iTxtHeight);    //控制滚动时文本区域的top

                //取消滚动时浏览器默认行为
                if (e.preventDefault){
                    e.preventDefault();        //FF
                }else{
                    window.event.returnValue = false;    //IE
                }
                return false;
            }
        }
    }
)(jQuery);

//去第几个li
function _goto(opts){
    var def={
        i:2,
        L:$(‘.left‘),
        l:$(‘.in‘),
        R:$(‘.right‘),
        r:$(‘.btn‘),
        t:300
    }
    var o = $.extend(def,opts);
    //滚动条的最大行程
    var iMaxHeight = o.R.outerHeight() - o.r.outerHeight();
    //滚动条的offsettop
    var iBoxTop = o.R.offset().top;
    //文本内容与外容器的高的差值
    var iTxtHeight = o.l.outerHeight() - o.L.outerHeight();
    //li的高度
    var liH = o.l.find(‘li‘).outerHeight();

    //计算左边行程
    var long1 = o.i*liH ;
    long1 = long1 > iTxtHeight ? iTxtHeight : long1;

    o.l.animate({
        top:-long1
    },o.t)

    //计算右边行程
    var long2 = long1/iTxtHeight*iMaxHeight;
    o.r.animate({
        top:long2
    },o.t);
}

 

滚动条

标签:

原文地址:http://www.cnblogs.com/anson0415/p/4233374.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!