温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何在css中使用position属性

发布时间:2021-04-02 16:59:58 来源:亿速云 阅读:153 作者:Leah 栏目:web开发

如何在css中使用position属性?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

position 属性值的含义:

static

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

relative

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

absolute

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

fixed

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

事实上默认的static和fixed这两种情况是比较容易辨别的,而容易混淆的是relative和absolute。

用更简单的说法就是absolute是将原本在文档流中所占的位置去掉,并以第一个非static定位的父元素进行定位,一般这样我们都会用top,left等来控制位置,这就是绝对定位。

而relative这种定位方式则是,在原有的文档流位置(也就是未设置POSITION属性的时候的位置)基础上移动。

所以当我们一般需要让某些元素随父元素移动而不会因为浏览器窗口大小变动而变形时,一般我们会把父元素定义为relative,而子元素定义为absolute,也就是说absolute是以第一个非static定位的父元素作为参考对象。

而一般我们会让内容居中,让margin:0 AUTO;就好了。

至于top和margin-top的区别,有些人可能分不清什么时候用,经常会用margin-top来实现定位,事实上这种做法是错误的,margin它是外边距,是占内容的,往往用这个来勉强实现定位都会使其他元素位置改变或导致其他效果,而这个效果并非我们想要的。

所以要认清absolute和relative的区别和用法,加上TOP LEFT RIGHT BOTTOM来定位就可以减少错误了。

顺带一提,CSS3之后多了挺多新属性的,自己还没一个个看,暂时记一下,background-size:cover;这个是本身就有还是后来才有的?我用DW8的时候并没有这个属性提示;

另外CSS3有很多属性IE是不能支持的,即使有那也是9甚至10以上才能兼容,所以在写的时候要注意浏览器的判断,根据不同浏览器设计不同的样式

<!--[if !IE]><!--> 除IE外都可识别 <!--<![endif]-->
<!--[if IE]> 所有的IE可识别 <![endif]-->
<!--[if IE 6]> 仅IE6可识别 <![endif]-->
<!--[if lt IE 6]> IE6以及IE6以下版本可识别 <![endif]-->
<!--[if gte IE 6]> IE6以及IE6以上版本可识别 <![endif]-->
<!--[if IE 7]> 仅IE7可识别 <![endif]-->
<!--[if lt IE 7]> IE7以及IE7以下版本可识别 <![endif]-->
<!--[if gte IE 7]> IE7以及IE7以上版本可识别 <![endif]-->
<!--[if IE 8]> 仅IE8可识别 <![endif]-->
<!--[if IE 9]> 仅IE9可识别 <![endif]-->

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI