position 属性介绍css
(1)position 属性自 CSS2 起就有了,该属性规定元素的定位类型。全部主流浏览器都支持 position 属性。html
(2)position 的可选值有四个:static、relative、absolute、fixed。下面分别进行介绍。(其实还有个 inherit,不过这个是 IE 特有的,这里就不作讨论)vue
1,基本介绍 (1)static 是默认值。表示没有定位,或者说不算具备定位属性。 (2)若是元素 position 属性值为 static(或者未设 position 属性),该元素出如今正常的流中(忽略 top, bottom, left, right 或者 z-index 声明)。node
2,使用样例react
css:git
<style>
div {
width: 200px;
height: 100px;
background-color: #C9FFFF;
}
</style>
复制代码
html:github
<div></div>
<input type="text"/>
复制代码
咱们不设置元素的 postion 属性值,那么默认的显示效果以下:web
1,基本介绍小程序
(1)relative 生成相对定位的元素,相对于其正常位置进行定位。 (2)相对定位完成的过程以下:微信小程序
首先按默认方式(static)生成一个元素(而且元素像层同样浮动了起来)。
而后相对于之前的位置移动,移动的方向和幅度由 left、right、top、bottom 属性肯定,偏移前的位置保留不动。
复制代码
2,样例代码
下面代码将文本输入框 position 设置为 relative(相对定位),而且相对于默认的位置向右、向上分别移动 15 个像素。
css:
div {
width: 200px;
height: 100px;
background-color: #C9FFFF;
}
input {
position: relative;
left: 15px;
top: -15px;
}
复制代码
html:
<div></div>
<input type="text" />
复制代码
运行效果以下:
详情见个人博客: alex-0407.github.io/blog/2018/0…
1,基本介绍
(1)absolute 生成绝对定位的元素。 (2)绝对定位的元素使用 left、right、top、bottom 属性相对于其最接近的一个具备定位属性的父元素进行绝对定位。 (3)若是不存在这样的父元素,则相对于 body 元素,即相对于浏览器窗口。
2,样例代码
下面代码让标题元素相对于它的父容器作绝对定位(注意父容器 position 要设置为 relative)。
同时经过 top 属性让标题元素上移,使其覆盖在父容器的上边框。
最后经过 left 和 margin-left 配合实现这个绝对定位元素的水平居中。
复制代码
css:
#box {
width: 200px;
height: 100px;
-webkit-box-flex:1;
border: 1px solid #28AE65;
border-radius:6px;
padding: 20px;
position: relative;
font-size: 12px;
}
#title {
background: #FFFFFF;
color: #28AE65;
font-size: 15px;
text-align: center;
width: 70px;
height: 20px;
line-height: 20px;
position: absolute;
top: -10px;
left: 50%;
margin-left: -35px;
}
复制代码
html:
<div id="box">
<div id="title">标题</div>
欢迎访问个人博客
</div>
复制代码
运行效果以下,标题元素虽然是在边框容器的内部。但因为其使用绝对定位,并作位置调整,最后显示效果就是覆盖在父容器边框上。
详情见个人博客: alex-0407.github.io/blog/2018/0…
1,基本介绍 (1)fixed 生成绝对定位的元素,该元素相对于浏览器窗口进行定位。 (2)固定定位的元素不会随浏览器窗口的滚动条滚动而变化,也不会受文档流动影响,而是始终位于浏览器窗口内视图的某个位置。
2,样例代码 (1)下面代码让输入框位于浏览器窗口的底部。
css:
input {
position: fixed;
bottom: 10px;
}
复制代码
html:
<ol>
<li>数据</li><li>数据</li><li>数据</li><li>数据</li><li>数据</li><li>数据</li>
<li>数据</li><li>数据</li><li>数据</li><li>数据</li><li>数据</li><li>数据</li>
<li>数据</li><li>数据</li><li>数据</li><li>数据</li><li>数据</li><li>数据</li>
<li>数据</li><li>数据</li><li>数据</li><li>数据</li><li>数据</li><li>数据</li>
</ol>
<input type="text" />
复制代码
(2)能够看到无论滚动条如何滚动,输入框始终处于窗口的最下方。
详情见个人博客: alex-0407.github.io/blog/2018/0…
更多angular1/2/4/五、ionic1/2/3/四、react、vue、微信小程序、nodejs等技术文章、视频教程和开源项目,请扫一扫下面的二维码关注微信公众号——全栈弄潮儿。
福利专区:扫码关注,免费领取淘宝天猫内部优惠券