前端 - css负边距的问题?
问题描述
这里有两个p, 都向左浮动,其中sub 设置了margin-left:-100%; 请问为何会出现这样的效果,sub能够占据到main上面。
在线demo:http://codepen.io/anon/pen/zvJeNG
请问这个负边距有何妙用,为何-100% 和 -190px(p的宽度)效果截然不同呢?
<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8' /> <title>Document</title></head><body> <p class='main'> this is main</p> <p class='sub'> this is sub </p> </body></html>
.main{ float:left; width:100%; background-color:aqua;}.sub{ float:left; width: 190px; margin-left:-100%; background-color:black; }
问题解答
回答1:margin值是百分比数的时候,是相当于元素的包含块的width来计算的
你这儿的.sub margin-left:-100%的100% 是相对于sub的包含块 body的width 来计算也就是body的宽度
而-190px就只是190个像素
回答2:1、这两个p都设置了左浮动,当body的宽度足够他们俩平排在一起的时候,他们一定会排在同一行。2、sub设置了-100%,这个100%是相对于它的父元素body的宽度,也就是说它等于body的宽度,所以,它就回到了最左边,而sub的宽度为190px,那就是从最左边开始排列,就是现在这个样式。
相关文章:
1. dockerfile - 我用docker build的时候出现下边问题 麻烦帮我看一下2. java - SpringMvc没有根据&符号截取参数3. javascript - 粘贴一段带有图片和文字的内容,如何使用js实现获取图片并上传到服务器?4. java编程思想第4版中文版的几处谬误?5. java - Android Studio编译打包Apk出现错误6. mongodb的java开发中使用两个字段相等查询条件应该怎么写?7. java - C语言的一道算法题-兄弟郊游问题 求解?8. Mongodb web连接28017后,提示登录的用户名密码在 db那里预设置9. java - 做数据库向手机端的推送要系统地学习哪些知识?求大神指点,谢谢!10. java - jdbc无法连接postgresql数据库