基于jquery的垂直滚动触发器,多参数可设置。

最近闲来无事,多封装些功能性组件。后期会有更多放出来,大家可以多关注一下。

先上参数:

type:"show",           默认为“show”,“show”意为当能够在可视区看到指定位置的节点时触发,“scroll”意为浏览器滚动过指定结点时触发。
            pos:"#scrollBox",       默认为"#scrollBox",通过此结点获取指定位置。
            delayDistance:0,       在指定位置的上下浮动距离,单位为像素,可为负值。
            single:true,            是否只触发一次。 true(是)、false(不是)
            passCallback:function(){},    超过指定位置的触发函数。
            backCallback:function(){}     小于指定位置时的触发函数。

demo如下:

1.html

<body style="height: 6000px;">

<div style="height: 1000px;background:#ff0"></div>
<div id="trigger1" style="height: 1500px;background: #f00;"></div>

</div>

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");
            }
    })
时间: 2024-11-05 18:28:32

基于jquery的垂直滚动触发器,多参数可设置。的相关文章

jquery文字垂直滚动代码实例

jquery文字垂直滚动代码实例: 文字垂直滚动效果在大量网站都有应用,尤其在新闻公告或者新闻列表之类形式的功能结构中出现. 代码实例如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.51texiao.cn/" /> <title>蚂

基于jquery的鼠标滚动放大缩小图片

一直以来都想写一个图片放大和缩小的小玩意,本来以为会很复杂,这几天自己思考了一下,原来是so easy啊.目前实现的放大缩小,主要时依据鼠标的滚轮触发事件来实现的,废话少说直接上源码. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns

基于 jQuery 实现垂直滑动的手风琴效果

今天我们要与大家分享一个漂亮而灵活的垂直 jQuery 手风琴效果.其主要思想是扩大手风琴片上的点击和显示更多的信息.其他内容片段将变得不那么透明.当使用一个导航箭头导航下一个片段,新的片会从顶部或底部滑动. 效果演示     插件下载 HTML 示例代码: <div id="va-accordion" class="va-container"> <div class="va-nav"> <span class=&q

基于jQuery左侧小图滚动右侧大图显示代码

今天给大家分享一款 jQuery左侧小图滚动右侧大图显示代码是一款基于jQuery实现的左侧滚动图片点击大图查看效果代码.该实例适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class="caseImg03 w1002"> <div class="slideCase03"> <div class=&q

基于jQuery实现页面滚动时顶部导航显示隐藏效果

<!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>Title</title> <link rel=&quo

jQuery BreakingNews 间歇滚动

BreakingNews 是一款基于jQuery的间歇滚动插件.它可以设置标题.标题颜色.标题背景颜色.链接颜色.字体大小.边框.宽度.自动滚动.间歇时间等等,同时它还好提供两种过度方式——淡入淡出(fade)和向上滑动(slide). 在线实例 实例演示 使用方法 <div class="BreakingNewsController easing" id="breakingnews1">      <div class="bn-titl

基于JQuery实现滚动到页面底端时自动加载更多信息

基于JQuery实现滚动到页面底端时自动加载更多信息 关键代码: 代码如下: var stop=true; $(window).scroll(function(){ totalheight = parseFloat($(window).height()) + parseFloat($(window).scrollTop()); if($(document).height() <= totalheight){ if(stop==true){ stop=false; $.post("ajax.

基于jquery的锚点滚动插件(百度百科效果) anchorScroll.js

1.插进使用场景 请打开https://baike.baidu.com/item/%E6%97%A5%E6%9C%AC%E5%8A%A8%E7%94%BB#hotspotmining,查看百度百科页面效果. 2.插件源代码: /* * 作者:孟繁贵 * 2017-08-25 * 版本:1.0 */ jQuery.anchorScroll = function(elem1, elem2) { var currObj, offsetTop = 0, h2List = new Array(), h3L

基于jQuery垂直多级导航菜单代码

基于jQuery垂直多级导航菜单代码是一款黑色风格的jQuery竖直导航菜单特效下载.效果图如下: 在线预览   源码下载 实现的代码. html代码: <ul class="ce"> <li> <a class="xz" href="#">目录A</a> </li> <li> <a href="#">目录B <img class=&qu