怎么让DIV固定在页面的某个位置而不随着滚动条随意滚动?

怎么让DIV固定在页面的某个位置而不随着滚动条随意滚动?,第1张

可用的方法比较多,比较常见的是使用CSS。

1、使用CSS

CSS让DIV固定位置不随滚动条而滚动,fixed元素的绝对位置是相对于HTML元素来说,滚动条是body元素的。

(1)我们需要做的是,让body保持其原有高度,让html只有一个窗口那么高。代码我们可以这样写:

html{overflow:hidden} 

body{height:100%overflow:auto}

(2)我们可以利用绝对定位来定位我们想要固定在窗口某个位置的模块。假设我们要固定的内容在右上。

html{overflow:hidden}

body{height:100%overflow:auto}

#rightformform{position:absoluteright:30pxtop50px}

(3)页面由左侧菜单和右侧主体内容构成,右侧内容可能会很多,会出现翻屏。现在是要无论页面怎么翻屏滚动,左侧的菜单始终在左侧。请看CSS解决方案。

#site_nav{position:fixedwidth:160pxpadding:6px10pxheight:100%  

background:#ffcoverflow-y:auto} 

#content{padding:10px10px10px190px}

(4)我设置左侧div#site_nav的样式,将其位置固定,即position:fixed,并且设置固定宽度,高度为100%,为了区分右侧内容,我设置了背景颜色background:#ffc。

接着,我将内容部分div#content设置其padding值,注意关键是padding-left:190px,只有大于左侧菜单宽度的padding值,才能使右侧主体内容部分不会与左侧菜单重叠。

2、不使用JS:

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<htmlxmlns="http://www.w3.org/1999/xhtml">

<head>

<metahttp-equiv="Content-Type"content="text/htmlcharset=utf-8"/>

<title>无标题文档</title>

<styletype="text/css">

ul{

margin:0

padding:0}

li{

list-style-type:nonefloat:leftmargin-left:10pxline-height:30px}

</style>

</head>

<body>

<divstyle="width:100%height:30pxbackground-color:#093position:fixedleft:0pxtop:0px">

<ul>

<li>sd</li>

<li>dsda</li>

<li>dsa</li>

</ul>

</div>

<divstyle="height:10000pxborder:1pxsolidred"></div>

<divstyle="width:100%height:30pxbackground-color:#093position:fixedleft:0pxbottom:0"></div>

</body>

</html>

3、<html>

<head>

<title></title>

<style type="text/css">

html,body {

overflow:hidden

margin:0px

width:100%

height:100%

}

.virtual_body {

width:100%

height:100%

overflow-y:scroll

overflow-x:auto

}

.fixed_div {

position:absolute

z-index:2008

bottom:20px

left:40px

width:800px

height:40px

border:1px solid red

background:#e5e5e5

}

</style>

</head>

<body>

<div class="fixed_div">I am still here!</div>

<div class="virtual_body">

<div style="height:888px">

I am content !

</div>

</div>

分析:

1、html,body:将默认可能会随机出现的滚动条,完全地隐藏了,这样不管您放了啥内容,它们都不会出来了。

2、.virtual_body:顾名思义,就是一个假的body了,它被设置为长宽都为100%的,意思就是它利用了所有可视的浏览器窗体显示所有的内容,并垂直允许出现滚动条。

3、.fixed_div:这下它可以利用绝对值进行定位了,因为在这个场景下,这个页面100%地被那个假冒的body给独霸了,而滚动条反正也出不来,您就可以自认为是在某个点蹲坑了,绝对安全。

可以使用css中的position来对div进行定位来改变div的位置,position属性值的含义:

static:元素框正常生成。块级元素生成一个矩形框,作为文档流的一部分,行内元素则会创建一个或多个行框,置于其父元素中。

relative:元素框偏移某个距离。元素仍保持其未定位前的形状,它原本所占的空间仍保留。

absolute:元素框从文档流完全删除,并相对于其包含块定位。包含块可能是文档中的另一个元素或者是初始包含块。元素原先在正常文档流中所占的空间会关闭,就好像元素原来不存在一样。元素定位后生成一个块级框,而不论原来它在正常流中生成何种类型的框。

fixed:元素框的表现类似于将position设置为absolute,不过其包含块是视窗本身。

提示:相对定位实际上被看作普通流定位模型的一部分,因为元素的位置相对于它在普通流中的位置。

jquery给一个DIV设置坐标:\x0d\x0ajquery中设置div的坐标位置的方法是通过offset实现的。\x0d\x0a1、获取到div对象并且获取到当前偏移位置\x0d\x0avar p = $("#elementId")对象\x0d\x0avar offset = p.offset()位置\x0d\x0a2、设置坐标位置,一般之关系距离顶部和左部的坐标:\x0d\x0a$("#secondElementId").offset({ top: offset.top, left: offset.left})


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/6899009.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-29
下一篇 2023-03-29

发表评论

登录后才能评论

评论列表(0条)

保存