html 菜单左右滑动效果,JQuery实现左右滚动菜单特效

自定义样式,由于本人水平欠佳,不能作出更加通用的东西,呵呵.

*

* 参数解释

* content: 内容元素,可以是选择器或JQUERY封装的DOM元素

* render: 渲染到的目标容器,可以是选择器或JQUERY封装的DOM元素

* options: 选项

* scrollable_class: 整体scrollable的外框架样式,默认: ui-scrollable

* scrollable_left_class: 左按钮的样式,默认: ui-scrollable-left

* scrollable_container_class: 内容容器的样式,默认: ui-scrollable-container

* scrollable_right_class: 右按钮的样式,默认: ui-scrollable-right

* delay: 鼠标放上或点击按钮时两次移动之间的时间间隔,整数

* speed: 鼠标放上按钮时,一次移动的距离,整数

* speedup: 鼠标点下按钮时,整数

* resizeEvent: 是否监听窗口改变大小的事件,布尔值,* 监听窗口改变大小时,在刷新页面后,感觉显示有点别扭,所以默认了false

* beforeScroll: 内容滚动时候的事件回调方法.

* 接受参数(两个对象): 第一个是滚动前内容左右位置,第二个是滚动后内容左右位置.

* 注意: 该事件可以使内容不受边界限制的滚动.

*/

options.scrollable_class = options.scrollable_class || 'ui-scrollable';

options.scrollable_left_class = options.scrollable_left_class || 'ui-scrollable-left';

options.scrollable_container_class = options.scrollable_container_class || 'ui-scrollable-container';

options.scrollable_right_class = options.scrollable_right_class || 'ui-scrollable-right';

options.leftText = options.leftText || '';

options.rightText = options.rightText || '';

options.delay = options.delay || 20;

options.speed = options.speed || 5;

options.speedup = options.speedup || 10;

options.resizeEvent = options.resizeEvent || false;

var render = (typeof render == 'string' ? $(render) : render);

var content = (typeof content == 'string' ? $(content) : content);

var scrollable = $('

')

.attr('id','scrollable_' + content.attr('id'))

.attr('className',options.scrollable_class);

var left = $('

')

.attr('id','scrollableleft' + content.attr('id'))

.attr('className',options.scrollable_left_class);

left.text(options.leftText);

var container = $('

')

.attr('id','scrollablecontainer' + content.attr('id'))

.attr('className',options.scrollable_container_class);

content.css('line-height','29px')

.css('position','relative')

.css('left','0px')

.css('overflow','hidden')

.css('float','left');

var right = $('

')

.attr('id','scrollableright' + content.attr('id'))

.attr('className',options.scrollable_right_class);

right.text(options.rightText);

show = function() {

scrollable.appendTo(render);

container.appendTo(scrollable);

left.css('display','');

right.css('display','');

content.appendTo(container);

left.prependTo(scrollable);

right.appendTo(scrollable);

if(content.width() <= container.width() + 20) {

scrollable.remove('.' + options.scrollable_left_class);

scrollable.remove('.' + options.scrollable_right_class);

left.css('display','none');

right.css('display','none');

container.width(content.width());

scrollable.width(container.width());

}

container.position = {left: container.css('left').substr(0,-2)}

container.position.right = container.position.left + container.width();

content.position = {left: new Number(content.css('left').substr(0,-2))}

content.position.right = content.position.left + content.width();

};

show();

var originalBroswerWidth = document.body.clientWidth;

window.onresize = function() {

if(options.resizeEvent) {

var newBroswerWidth = document.body.clientWidth;

var percent = newBroswerWidth / originalBroswerWidth;

container.width(container.width() * percent);

scrollable.width(container.width() + left.width() + right.width());

show();

}

originalBroswerWidth = document.body.clientWidth;

}

var scroll = false;

move = function(distance) {

var newLeft = content.position.left + distance;

var newRight = content.position.right + distance;

if(distance > 0 && newLeft > container.position.left) {

distance = container.position.left - content.position.left;

scroll = false;

} else if(distance < 0 && newRight < container.position.right) {

distance = content.position.right - container.position.right;

scroll = false;

}

newLeft = content.position.left + distance;

newRight = content.position.right + distance;

scorll = beforeScroll ? beforeScroll(

{left: content.position.left,right: content.position.right},{left: newLeft,right: newRight}) : scroll;

if(scroll) {

content.css('left',newLeft + 'px');

content.position.left += distance;

content.position.right += distance;

setTimeout('move(' + distance + ')',options.delay);

}

}

left.mouSEOver(function() {

scroll = true;

move(options.speed);

});

right.mouSEOver(function() {

scroll = true;

move(-options.speed);

});

left.mouSEOut(function() {

scroll = false;

});

right.mouSEOut(function() {

scroll = false;

});

left.mousedown(function() {

scroll = true;

move(options.speedup);

});

right.mousedown(function() {

scroll = true;

move(-options.speedup);

});

left.mouseup(function() {

scroll = false;

});

right.mouseup(function() {

scroll = false;

});

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值