JQuery实现左右滚动菜单特效

前端之家收集整理的这篇文章主要介绍了JQuery实现左右滚动菜单特效前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

经过了半天的时间,这个使用JQuery开发出来的左右滚动菜单功能也算是完成了,暂时还没有发现错误的现象。现在把代码完整的代码拿出来分享

scrollable.js

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;
});
}

Default.aspx

JQuery左右滚动菜单特效页面代码引用片段:

<Meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> JQuery左右滚动<a href="https://www.jb51.cc/tag/caidan/" target="_blank" class="keywords">菜单</a>特效
菜单一
菜单二
菜单三
菜单四
菜单五
菜单六
菜单七
菜单八
菜单九
菜单十
菜单一
菜单二
菜单三
菜单四
菜单五
菜单六
菜单七
菜单八
菜单九
菜单十

当然,我们还需要引用JQuery框架文件,我这里用的是

jquery-1.4.2.min.js

,自己可以在网上搜索下载,我就不上传到这里了。整个JQuery左右滚动菜单特效就是这个样子了,自己觉得还行,希望能帮到一些有需要的朋友。

原文链接:https://www.f2er.com/jquery/52231.html

猜你在找的jQuery相关文章