基于JQ的平滑滚动到顶部插件
2017-05-08 10:19
246 查看
点击一个固定按钮,平滑的滚动到窗口顶部的这种功能,在前端开发是相当常见的,如图:
$.fn.scrollTo = function(options) {
var defaults = {
toT: 0, //滚动目标位置
durTime: 500, //过渡动画时间
delay: 30, //定时器时间
callback: null //回调函数
};
var opts = $.extend(defaults, options),
timer = null,
_this = this,
curTop = _this.scrollTop(), //滚动条当前的位置
subTop = opts.toT - curTop, //滚动条目标位置和当前位置的差值
index = 0,
dur = Math.round(opts.durTime / opts.delay),
smoothScroll = function(t) {
index++;
var per = Math.round(subTop / dur);
if (index >= dur) {
_this.scrollTop(t);
window.clearInterval(timer);
if (opts.callback && typeof opts.callback == 'function') {
opts.callback();
}
return;
} else {
_this.scrollTop(curTop + index * per);
}
};
timer = window.setInterval(function() {
smoothScroll(opts.toT);
}, opts.delay);
return _this;
};
//调用
$("body").scrollTo({ toT: 0 });
$.fn.scrollTo = function(options) {
var defaults = {
toT: 0, //滚动目标位置
durTime: 500, //过渡动画时间
delay: 30, //定时器时间
callback: null //回调函数
};
var opts = $.extend(defaults, options),
timer = null,
_this = this,
curTop = _this.scrollTop(), //滚动条当前的位置
subTop = opts.toT - curTop, //滚动条目标位置和当前位置的差值
index = 0,
dur = Math.round(opts.durTime / opts.delay),
smoothScroll = function(t) {
index++;
var per = Math.round(subTop / dur);
if (index >= dur) {
_this.scrollTop(t);
window.clearInterval(timer);
if (opts.callback && typeof opts.callback == 'function') {
opts.callback();
}
return;
} else {
_this.scrollTop(curTop + index * per);
}
};
timer = window.setInterval(function() {
smoothScroll(opts.toT);
}, opts.delay);
return _this;
};
//调用
$("body").scrollTo({ toT: 0 });
相关文章推荐
- 基于jQuery图片平滑连续滚动插件
- 基于jQuery图片平滑连续滚动插件
- 基于jQuery图片平滑连续滚动插件
- 基于jQuery图片平滑连续滚动插件(转)
- 用jQuery为跳转链接锚点添加平滑滚动动画效果(如回到顶部
- jQuery创建平滑的页面滚动(顶部或底部)
- vue平滑滚动到顶部
- 基于jQuery的自用滚动插件
- jcarousellite.js 基于Jquery的图片无缝滚动插件
- JQ插件第五十:文字列表无缝向上滚动
- 基于JQ返回顶部代码
- ionic-基于angularjs实现沉浸式顶部导航栏,滚动时产生渐变效果
- js平滑滚动到顶部,底部,指定地方
- 基于jQuery的图片左右无缝滚动插件
- jq插件第二款来袭 图片滚动
- [jQuery插件] Sly:灵活的基于ITEM的滚动插件
- 拿来就用,基于jq的pc+移动端头像上传插件
- js平滑滚动到顶部,底部,指定地方
- 超级有用的13个基于jQuery的内容滚动插件和教程
- 基于jquery的图片滚动插件代码