博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CSS学习笔记——定位position属性的学习
阅读量:4625 次
发布时间:2019-06-09

本文共 1777 字,大约阅读时间需要 5 分钟。

今天学习之前剩下的一个问题:CSS的position属性首先归纳出和position相关的问题:

  1. position作为一个属性,它一共有哪几个属性值?
  2. position常用的属性值有哪几个?分别有什么特点?

第一个问题:position作为一个属性,它一共有哪几个属性值? 

  对于position属性,他一共有5个值,分别是

  1. static:默认值。没有定位,元素出现在正常的流中。
  2. relative:生成相对定位的元素,相对于其正常位置进行定位。正常位置也就是指如果没有position属性它会出现的位置。
  3. absolute:生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。这里需要注意一下,absolute的参照对象是第一个拥有非static的position属性的父级元素,后面会详细解释。
  4. fixed:生成绝对定位的元素,相对于浏览器窗口进行定位。
  5. 规定应该从父元素继承 position 属性的值。

  这种定义性质的问题,一般在W3cSchool上可以找到最标准的的答案,这5种属性的解释已经非常详细。其实我们在开发中经常用的只有relative、absolute、fixed这3个属性,另外当给元素增加了这是种属性中的任意一种,我们也就需要根据情况设置元素的left/top/right/bottom以及z-index,元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定,显示层级通过z-index控制。

第二个问题:position常用的属性值有哪几个?分别有什么特点?

  上面已经提到了我们常用的3个属性值:relative、absolute、fixed。

  relative:元素的position属性设置为relative后,这个元素会以自己之前的位置为参照,根据设置的left等值进行移动。下面举个栗子~

    
Title

代码的效果如下图:

  第二个div是根据它之前的位置进行了移动,并且它之前的位置并没有被后面的元素占据。红色的div被黄色的div遮盖是因为z-index的作用。

  absolute:对于position属性是 static 定位以外的第一个父元素进行定位。这里需要详细分析一下这句话:首先我们可以判断出,absolute定位参照的对象是它拥有定位属性的父级元素;然后,这个父级元素的position属性不能是static。

  这里再想细一点:如果元素没有拥有position属性的父级元素怎么办? 这里我通过查资料确定了这种情况它会根据<html>标签也就是页面的根节点进行定位。(注意是<html>标签)

下面将div2的position属性改为absolute查看效果:

  这样我们就可以发现红色div移动之前的位置会被黄色的占据,这时候其实表示红色的div已经脱离了文档流。

  最后一个属性值:fixed.它的效果其实和absolute类似,都属于绝对定位,但是它的参照则是固定的浏览器窗口。修改div2的position属性改为fixed后,滚动鼠标滚轴就可以查看效果,利用这个特性我们可以做出类似侧边悬浮窗(某些网站侧边的小广告(ノಠ益ಠ)ノ彡┻━┻)这样的效果。

  其实,我在学习position过程中感觉到,掌握好元素的参照物是理解position属性的关键,确定好参照物,然后再根据属性值的类型判断后面的元素的状态,就能确定好元素的位置啦~

PS:通过这几天自己提问自己想办法解答的学习过程,真的收获很多。其实平时学习过程中忽略的细节还是很多的,经历了这样的一个过程自己的基础知识又扎实了不少~另外我还发现利用博客来分享知识更是个快乐的过程,又能提高编程技术又能提高表达能力,同时还有可能帮助到别人,所以一定要坚持下去!!(╰_╯)#

2016年1月11日

不积跬步,无以至千里

 

PS:我查阅的大部分资料都是来自于网络,如有侵权,请联系我删除

转载于:https://www.cnblogs.com/laobeiV5/p/5121949.html

你可能感兴趣的文章
SQL server函数大全
查看>>
玩转JavaScript正则表达式
查看>>
Sticky Footer,完美的绝对底部
查看>>
Android动态加载——加载已安装APK中的类
查看>>
Python元组与列表的区别和联系?
查看>>
网络ISO分层结构
查看>>
人生第一次的自己完成的atm机
查看>>
用Fragment实现界面跳转
查看>>
不允许保存更改您所做的更改要求删除
查看>>
2、以自定义struct或struct指针作为map的Key
查看>>
YYHSOI模拟赛题解(T5卡片游戏)
查看>>
好程序员web前端技术分享移动端页面布局
查看>>
进度条的使用 Progress控件
查看>>
Java - 网络与多线程 - 多线程之内存可见性
查看>>
【自动化__持续集成】___java___水仙花
查看>>
实验任务一
查看>>
【转】【金蝶K3Cloud】 在插件中调用工作流
查看>>
数据库实验课笔记20190509
查看>>
HDU1131_卡特兰数算二叉树个数
查看>>
TortoiseSVN安装攻略和使用教程(详细)
查看>>