
基于jquery的垂直滚动触发器,多参数可设置。
发布日期:2021-05-09 05:52:52
浏览次数:17
分类:博客文章
本文共 3654 字,大约阅读时间需要 12 分钟。
最近闲来无事,多封装些功能性组件。后期会有更多放出来,大家可以多关注一下。
先上参数:
type:"show", 默认为“show”,“show”意为当能够在可视区看到指定位置的节点时触发,“scroll”意为浏览器滚动过指定结点时触发。
pos:"#scrollBox", 默认为"#scrollBox",通过此结点获取指定位置。 delayDistance:0, 在指定位置的上下浮动距离,单位为像素,可为负值。 single:true, 是否只触发一次。 true(是)、false(不是) passCallback:function(){}, 超过指定位置的触发函数。 backCallback:function(){} 小于指定位置时的触发函数。demo如下:
1.html
2.js(组件)
function scrollTrigger(obj){ this.set={ type:"show", pos:"#scrollBox", delayDistance:0, single:true, passCallback:function(){}, backCallback:function(){} } this.passFlag=false; this.backFlag=false; $.extend(this.set,obj) var _this=this; this.init=function(){ $(window).scroll(function(){ if(_this.set.type=="scroll"){ if($(window).scrollTop()>=$(_this.set.pos).offset().top+_this.set.delayDistance){ if(_this.set.single==true&&_this.passFlag==false){ _this.set.passCallback(); _this.passFlag=true; }else if(_this.set.single==true&&_this.passFlag==true){ }else{ _this.set.passCallback(); } } if($(window).scrollTop()<$(_this.set.pos).offset().top+_this.set.delayDistance){ if(_this.set.single==true&&_this.backFlag==false){ _this.set.backCallback(); _this.backFlag=true; }else if(_this.set.single==true&&_this.backFlag==true){ }else{ _this.set.backCallback(); } } } if(_this.set.type=="show"){ if($(window).scrollTop()>=$(_this.set.pos).offset().top-$(window).height()+_this.set.delayDistance){ if(_this.set.single==true&&_this.passFlag==false){ _this.set.passCallback(); _this.passFlag=true; }else if(_this.set.single==true&&_this.passFlag==true){ }else{ _this.set.passCallback(); } } if($(window).scrollTop()+$(window).height()<$(_this.set.pos).offset().top+_this.set.delayDistance){ if(_this.set.single==true&&_this.backFlag==false){ _this.set.backCallback(); _this.backFlag=true; }else if(_this.set.single==true&&_this.backFlag==true){ }else{ _this.set.backCallback(); } } } }) } this.init(); }
3. js (调用)
var trigger1=new scrollTrigger({ type:"show", pos:"#trigger1", single:false, delayDistance:0, passCallback:function(){ console.log("pass"); }, backCallback:function(){ console.log("back"); } })
发表评论
最新留言
不错!
[***.144.177.141]2025年03月25日 08时17分12秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Python3获取新浪微博内容乱码问题
2019-03-06
移动开发中单页异步加载所有列表项
2019-03-06
Newbe.Claptrap 框架入门,第一步 —— 开发环境准备
2019-03-06
最大子序列和问题
2019-03-06
【neo4j】文件管理路径、数据备份、创建新数据库、导入数据等操作记录
2019-03-06
Python中字符串前添加r ,b, u, f前缀的含义
2019-03-06
zookeeper安装部署步骤
2019-03-06
Linux I/O 重定向
2019-03-06
Hadoop学习笔记—Yarn
2019-03-06
对象的绑定方法
2019-03-06
__format__
2019-03-06
大白话OSI七层协议
2019-03-06
十天快速入门Python(目录)
2019-03-06
008 Python基本语法元素小结
2019-03-06
026 模块3-random库的使用
2019-03-06
027 实例6-圆周率的计算
2019-03-06
小白专场-树的同构-python语言实现
2019-03-06
191006
2019-03-06