js或者jquery实现div不随滚动条滚动

我想请教大家如何js让div不随滚动条滚动但是当到达该div的父亲div的边缘的时候它随父亲div滚动,换句话说,就是有两个div<divid=div1><divid=d... 我想请教大家 如何js让div不随滚动条滚动 但是当到达该div的父亲div的边缘的时候 它随父亲div滚动,换句话说,就是有两个div
<div id=div1>
<div id=div2></div>
</div>
我希望让div2在div1的高度范围内不随滚动条滚动,当div2到达div1边缘时随着div1滚动
我想要那个效果 求实现方法
展开
 我来答
yu641150278
推荐于2016-04-27 · TA获得超过1069个赞
知道小有建树答主
回答量:637
采纳率:100%
帮助的人:295万
展开全部
试试这样的吧
<body>
<div id="box" style="height:2000px;width:3000px;">
<div id="div1" style="width:500px;height:500px;background:green;position:absolute;">
    <div id="div2" style="width:200px;height:100px;background:lightblue;position:fixed;">里面的div</div>
</div>
</div>
</body>
<script type="text/javascript">
var sTop = 0;            //初始卷起的高度
var sLeft = 0;            //初始卷起的宽度
var p_div = document.getElementById("div1");        //父div
var max_x = p_div.offsetLeft+p_div.offsetWidth;        //父div的右边界
var max_y = p_div.offsetTop+p_div.offsetHeight;        //父div的下边界
window.onscroll = function(){
    var c_div = document.getElementById("div2");    //子div
    var s_top = document.documentElement.scrollTop || document.body.scrollTop;            //卷起的高度
    var s_left = document.documentElement.scrollLeft || document.body.scrollLeft;        //卷起的宽度
    if(s_top!=sTop){        //纵向滚动,当前卷起的高度和原卷起的高度不一致
        sTop = s_top;        
        c_y = s_top+p_div.offsetTop+c_div.offsetHeight;            //子div当前的下边界坐标
        if(c_y>=max_y){                //如果下边界超过父div下边界
            c_div.style.position = "relative";
            c_div.style.top = (p_div.offsetHeight-c_div.offsetHeight)+"px";
            c_div.style.left = s_left+"px";
        }else{
            c_div.style.position = "fixed";
            c_div.style.top = "";
            c_div.style.left = "";
        }
    }
    if(s_left!=sLeft){        //纵向滚动
        sLeft = s_left;
        c_x = s_left+p_div.offsetLeft+c_div.offsetWidth;
        if(c_x>=max_x){
            c_div.style.position = "relative";
            c_div.style.left = (p_div.offsetWidth-c_div.offsetWidth)+"px";
            c_div.style.top = s_top+"px";
        }else{
            c_div.style.position = "fixed";
            c_div.style.left = "";
            c_div.style.top = "";
        }
    }
}
</script>
100218685
2013-10-22 · 超过12用户采纳过TA的回答
知道答主
回答量:34
采纳率:0%
帮助的人:29.7万
展开全部

先了解了 css 的 position:fixed; 属性


了解 jquery

  1. 如何获得容器的位置

  2. 如何获得滚动条的位置

使用$(window).scroll(function(){

})  每次页面滚动的时候都会触发它


然后看你的了

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
小周5161
2013-10-22
知道答主
回答量:19
采纳率:100%
帮助的人:7.7万
展开全部
我感觉整体思路应该是:首先你要是想让div不随滚动条滚动,肯定是有一个position:fixed
然后就是绑定onscroll事件,检测什么时候达到你要求的临界值,改变div
的position:fixed就可以了。至于你的临界值是个什么情况,你可以在具体
百度一下搜一搜了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
longwu90604017
2013-10-22 · TA获得超过205个赞
知道小有建树答主
回答量:214
采纳率:100%
帮助的人:71.9万
展开全部
css就可以了。
#div1{
height:300px;
overflow-y:auto;
}

#div2{
height:150px;
position:fixed;

}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式