jQuery Scrollify

Version Beta v1.0.5

Date:2017-04-25 23:45

源代码##

(function($, window, document) {

	'user strict';

	var whellEvt = document.onmousewheel !== undefined ? 'mousewheel' : 'DOMMouseScroll';
var $window = $(window);
var $document = $(document);
var easing = 'easeOutExpo';
var sHeight = $window.height();
var top = $window.scrollTop();
var heights = [];
var elements = [];
var index = 0;
var isMove = false;
var target = 'body,html';
var scrollBar = false;
var timeout = null;
var isRelaod = true;
var _isIE = false;
var _TIMEOUT_ID_ONE = 0;
var _TIMEOUT_ID_TWO = 0; var settings = {
extraSelector: '',
selector: 'section',
minHeight: 0,
scrollingSpeed: 8e2,
easing: 'easeInOutQuart',
target: 'body,html',
before: function() {},
after: function() {}
}; function sizePanles() {
if (settings.selector) { var selector = '.' + settings.selector,
winHeight = $window.height(); $(selector).each(function() { var $this = $(this); if (!$this.is('.' + settings.extraSelector)) { if (settings.minHeight < winHeight) {
$this.css('height', winHeight);
} else {
$this.css('height', settings.minHeight);
}
} }); }
} function calcePosition() { if (settings.selector) {
var selector = '.' + settings.selector; if (settings.extraSelector) {
selector += ',.' + settings.extraSelector;
} $(selector).each(function(i) {
var $this = $(this); if ($this.is(settings.extraSelector)) {
heights[i] = heights[heights.length - 1] + $this.height();
} else {
heights[i] = $this.offset().top;
}
});
}
} function isScrollEnd(detail) { var scrollBarTime = new Date().getTime(),
diff = 0; top = $window.scrollTop();
sHeight = $window.height(); if (settings.minHeight <= sHeight) {
return true;
} if (detail > 0) { if (top > 0 && index === 0) {
animateScroll(index);
return false;
} else {
return true;
} } else { diff = (settings.minHeight - sHeight) + settings.minHeight * index; if (scrollBarTime - _TIMEOUT_ID_ONE >= 10 && !isMove) { if (top < diff) {
$window.scrollTop(top += 60);
if (top >= diff) {
return true;
} else {
return false;
}
} else {
return true;
} _TIMEOUT_ID_ONE = scrollBarTime;
}
} } function getIndex(callback) { var i = 1,
l = heights.length,
closet = 0,
sHeight = $window.height(),
calcHeight = sHeight / 2,
time = time || 100; top = $window.scrollTop(); for (; i < l; i++) {
if (top + calcHeight >= heights[i]) {
closet = i;
}
} if (settings.extraSelector) { var $extraSelector = $('.' + settings.extraSelector),
extraHeight = $extraSelector.height(); if (top + sHeight > heights[l - 1] + extraHeight / 2) {
closet = l - 1;
}
} index = closet;
callback && callback(); } function isIE() { var b = document.createElement('b');
b.innerHTML = '<!--[if IE]><b></b><![endif]-->';
return !!b.getElementsByTagName('b').length; } function animateScroll(index) {
isMove = true;
settings.before(index);
$(settings.target).stop().animate({
scrollTop: heights[index]
}, settings.scrollingSpeed, settings.easing, function() {
settings.after(index);
isMove = false;
});
//$(settings.target).promise().done(function(){settings.after(index);});
} $.scrollify = function(options) { var core = { init: function() {
top = $window.scrollTop();
_isIE = isIE();
$window.on('scroll', core.scrollHandle);
$window.on('mousedown', core.mousedown);
$window.on('mouseup', core.mouseup);
$document.on(whellEvt, core.wheelHandle); },
mousedown: function() {
scrollBar = true;
},
mouseup: function() {
scrollBar = false;
if (top > 0) {
animateScroll(index);
}
},
wheelHandle: function(e) { var detail = (-e.originalEvent.detail || e.originalEvent.wheelDelta),
time = new Date().getTime(); if (scrollBar) {
scrollBar = false;
return true;
} isRelaod = false; if (isScrollEnd(detail)) { if (time - _TIMEOUT_ID_TWO > settings.scrollingSpeed) { if (_isIE) {
getIndex();
} if (detail < 0) {
if (index < heights.length - 1) {
index++;
animateScroll(index);
_TIMEOUT_ID_TWO = time;
}
} else { if (index > 0) {
index--;
animateScroll(index);
_TIMEOUT_ID_TWO = time;
}
}
}
} e.preventDefault();
e.returnValue = false; },
scrollHandle: function(e) { if (isRelaod) {
isRelaod = false;
getIndex(function() {
animateScroll(index);
}); } else {
if (scrollBar) {
if (timeout) {
clearTimeout(timeout);
timeout = null;
}
timeout = setTimeout(function() {
getIndex();
}, 100); }
}
}
} settings = $.extend(settings, options);
sizePanles();
calcePosition(); if (heights.length) { $window.on('resize', function() {
sizePanles();
calcePosition();
$window.scrollTop(heights[index]);
});
core.init();
} }; $.scrollify.move = function(idx) { if (idx >= 0 && idx < heights.length) {
index = idx;
animateScroll(index);
} } }(jQuery, window, document));

说明##

基于Jquery通过滚动滚动条实现的全屏滚动组件,相比于传统的fullpage方式的全屏滚动,它即可以通过滚动条滚动内容,也可以鼠标滚轮全屏滚动内容,使滚动条与全屏滚动有效的结合在一起。同时也支持非溢出的显示内容,在小屏幕下,多余的内容,可以通过额外的滚动全部显示完成后,才会滚动到下一屏。

该全屏组件支持IE7+,但是IE浏览器滚动条不支持 mouseDownmouseUp事件的原因,会有些瑕疵。

该组件目前是测试版本,不确保功能正常,我会继续跟踪改进,如果你有使用到,并且发生了问题,请与我联系:sgt_ah@163.com

使用##

调用方法:

$.scrollify({
'target':'body,html', //滚动的目标容器,默认值为body,html
'selector': 'section', //每个分区的类名,无需加点号.
'extraSelector': 'section-six', //特殊的分区,例如文网文
'minHeight': 600, //每个分区的最低高度,可以不设
'scrollingSpeed': 8e2, //滚动速度,默认值8e2
'easing':'easeInOutQuart', //滚动的动画速度方式。
'before':function, //回调函数,滚动之前
'after':function //回调函数,滚动之后
});

注意##

本组件依赖 jquery.easing 组件

scrollify - 滚动条方式的全屏滚动的更多相关文章

  1. Scrollify – jQuery全屏滚动插件

    和 fullPage.js 一样,Scrollify 也是一款基于 jQuery 的全屏滚动插件.跟 fullPage.js 相比,Scrollify 更加小巧,压缩后不足 4KB.但功能上不如 fu ...

  2. 自己用js实现全屏滚动

    参照fullPage.js的效果,用自己的想法实现的. 实现的效果:1.全屏滚动,滚动一下齿轮就会滚动全屏. 2.自适应缩放,无论怎么改变窗口的大小,都会保证用一个元素占满全屏. 下一步计划: 1.改 ...

  3. jquery.fullPage.js全屏滚动插件教程演示

    css部分(此处需要导入jquery.fullPage.css) <style> .section { text-align: center; font: 50px "Micro ...

  4. 全屏滚动-jQuery插件实现

    全屏滚动 <---很久没写了,这段忙了点,以后还是每周尽量写点东西---> 在很多情况下,我们需要页面的全屏滚动,尤其是移动端.今天简要的介绍一下全屏滚动的知识. 一.全屏滚动的原理 1. ...

  5. 《fullPage.js》创建全屏滚动的网站

    插件介绍 fullPage.js是一个简单易用的插件,创建全屏滚动的网站(也被称为单页网站).它允许全屏滚动创建网站,以及添加内部滑块. 浏览器兼容性 主要功能 支持鼠标滚动 支持前进后退和键盘控制 ...

  6. 拥抱单页网站! jQuery全屏滚动插件fullPage.js

    不知道从什么时候开始,单页网站就悄悄走进人们的视线,尤其是国外的网站,更是钟爱单页网站.制作一个全屏滚动的效果,然后每个滚动页弄一个好看的背景色,配上一些描述性的文字,大家都喜欢这么弄,仿佛逼格瞬间可 ...

  7. jQuery全屏滚动插件fullPage.js中文帮助文档API

    jQuery全屏滚动插件fullPage.js中文帮助文档API   发现了一个fullPage.js插件,于是百度了一下,还就是这个插件的作用,其实有很多网站都做了全屏滚动的特效,效果也很好看,今天 ...

  8. fullpage.js jq全屏滚动插件

    fullPage.js和fullPage都能实现全屏滚动,二者区别是:fullPage.js需依赖于JQuery库,而fullPage不需要依赖任何一个js库,可以单独使用. (代码演示效果并且可以下 ...

  9. FullPage.js-基于 jQuery 的插件全屏滚动插件

    fullPage.js 是一个基于 jQuery 的插件,它能够很方便.很轻松的制作出全屏网站.如今我们经常能见到全屏网站,尤其是国外网站.这些网站用几幅很大的图片或色块做背景,再添加一些简单的内容, ...

随机推荐

  1. EventBus猜想 ----手把手带你自己实现一个EventBus

    本文是什么 本文是一篇怀着推測角度学习一个未知东西(EventBus)的文章. 先推測EventBus是怎样实现的. 依据推測去模仿他的实现. 查看源代码.验证猜想. 更深入的去理解他. 转载请注明出 ...

  2. 基于 Asp.Net Core MVC 的 Angular4 SSR 英雄指南

    为啥有这篇文章 在之前,类似 Angular.React.Vue 之类的前端框架的一个痛点就是无法在服务端提前把网页内容写入到网页中再发回浏览器,这给网站的 SEO 增加了不少困难,因为爬虫爬到的页面 ...

  3. Can't update: no tracked branch No tracked branch configured for branch dev.

    1.git pull 命令出现以下错误 $ git pull There is no tracking information for the current branch. Please speci ...

  4. DotNetCore跨平台~System.DrawingCore部署Linux需要注意的

    回到目录 你在windows上使用图像组件没有任务问题,但部署到linux之后,将注意以下几点: 安装nuget包ZKWeb.System.Drawing 项目里还是引用System.DrawingC ...

  5. NYOJ915——+-字符串

    +-字符串 时间限制:1000 ms  |  内存限制:65535 KB 难度:1   描述 Shiva得到了两个只有加号和减号的字符串,字串长度相同.Shiva一次可以把一个加号和它相邻的减号交换. ...

  6. 小白的Python之路 day4 装饰器前奏

    装饰器前奏: 一.定义: 1.装饰器本质是函数,语法都是用def去定义的 (函数的目的:他需要完成特定的功能) 2.装饰器的功能:就是装饰其他函数(就是为其他函数添加附加功能) 二.原则: 1. 不能 ...

  7. 【CSS3】颜色表示方式

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  8. Python 项目实践二(生成数据)第二篇之随机漫步

    接着上节继续学习,在本节中,我们将使用Python来生成随机漫步数据,再使用matplotlib以引人瞩目的方式将这些数据呈现出来.随机漫步是这样行走得到的路径:每次行走都完全是随机的,没有明确的方向 ...

  9. Microsoft Visual Studio 2012旗舰版(VS2012中文版下载)官方中文版

    Microsoft Visual Studio 2012 Ultimate旗舰版(VS2012中文版下载)是一个最先进的开发解决方案,它使各种规模的团队能够设计和创建出使用户欣喜的引人注目的应用程序. ...

  10. windows 下的python 安装pycrypto

    一般在官方网站下载pycrypto: https://www.dlitz.net/software/pycrypto/   然后使用命令就可以安装成功了: python setup.py build  ...