一.外边距和内边

  • margin:            用于控制元素与元素之间的距离 外边距;margin的最基本用途就是控制元素周围空间的间隔,从视觉角度上达到相互隔开的目的。
  • padding:           用于控制内容与边框之间的距离 内边距;   
  • Border(边框)     围绕在内边距和内容外的边框。
  • Content(内容)   盒子的内容,显示文本和图像。
    margin:10px 5px 15px 20px;-----------上 右 下 左
    margin:10px 5px 15px;----------------上 右左 下
    margin:10px 5px;---------------------上下  右左
    margin:10px;    ---------------------上右下左
    
    注意:他们位置按顺时针排序 top right bottom left

    # 清除body外边距
    
    body{margin: 0 auto;
    } 

二.float属性 

block元素通常被现实为独立的一块,独占一行,多个block元素会各自新起一行,默认block元素宽度自动填满其父元素宽度。block元素可以设置width、height、margin、padding属性;

  inline元素不会独占一行,多个相邻的行内元素会排列在同一行里,直到一行排列不下,才会新换一行,其宽度随元素的内容而变化。inline元素设置width、height属性无效。inline元素的margin和padding属性。水平方向的padding-left, padding-right, margin-left, margin-right都产生边距效果;但竖直方向的padding-top, padding-bottom, margin-top, margin-bottom不会产生边距效果。

  • 常见的块级元素有 div、form、table、p、pre、h1~h5、dl、ol、ul 等。
  • 常见的内联元素有span、a、strong、em、label、input、select、textarea、img、br等

所谓的文档流,指的是元素排版布局过程中,元素会自动从左往右,从上往下的流式排列。

脱离文档流,也就是将元素从普通的布局排版中拿走,其他盒子在定位的时候,会当做脱离文档流的元素不存在而进行定位

只有绝对定位absolute和浮动float才会脱离文档流。

---部分无视和完全无视的区别?需要注意的是,使用float脱离文档流时,其他盒子会无视这个元素,但其他盒子内的文本依然会为这个元素让出位置,环绕在周围(可以说是部分无视)。而对于使用absolute position脱离文档流的元素,其他盒子与其他盒子内的文本都会无视它。(可以说是完全无视)

浮动的表现

定义:浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。由于浮动框不在文档的普通流中,所以文档的普通流中的浮动框之后的块框表现得就像浮动框不存在一样。(注意这里是块框而不是内联元素;浮动框只对它后面的元素造成影响)

注意 当初float被设计的时候就是用来完成文本环绕的效果,所以文本不会被挡住,这是float的特性,即float是一种不彻底的脱离文档流方式。无论多么复杂的布局,其基本出发点均是:“如何在一行显示多个div元素”。

清除浮动:

在非IE浏览器(如Firefox)下,当容器的高度为auto,且容器的内容中有浮动(float为left或right)的元素,在这种情况下,容器的高度不能自动伸长以适应内容的高度,使得内容溢出到容器外面而影响(甚至破坏)布局的现象。这个现象叫浮动溢出,为了防止这个现象的出现而进行的CSS处理,就叫CSS清除浮动。

clear语法:
clear : none | left | right | both
取值:
none : 默认值。允许两边都可以有浮动对象
left : 不允许左边有浮动对象
right : 不允许右边有浮动对象
both : 不允许有浮动对象
但是需要注意的是:clear属性只会对自身起作用,而不会影响其他元素。如果一个元素的右侧有一浮动对象,而这个元素设置了不允许右边有浮动对象,即clear:right,则这个元素会自动下移一格,达到本元素右边没有浮动对象的目的。

1.创建方式

# 新建一个清除浮动伪类 写在css代码里.clearfix:after {             <----在类名为“clearfix”的元素内最后面加入内容;
content: ".";                 <----内容为“.”就是一个英文的句号而已。也可以不写。
display: block;               <----加入的这个元素转换为块级元素。
clear: both;                  <----清除左右两边浮动。
visibility: hidden;           <----可见度设为隐藏。注意它和display:none;是有区别的。visibility:hidden;          仍然占据空间,只是看不到而已;
line-height: 0;               <----行高为0;
height: 0;                    <----高度为0;
font-size:0;                  <----字体大小为0;
}
.clearfix { *zoom:1;}         <----这是针对于IE6的,因为IE6不支持:after伪类,这个神奇的zoom:1让IE6的元素可以清除浮动来包裹内部元素。只要写一个.clearfix就行了,然后在需要清浮动的元素中 添加clearfix类名就好了。
如:
<div class="head clearfix"></div>

三.position

static,默认值,去除元素的定位。也就是不进行定位relative,相对定位,元素相对于自身原来的位置进行定位。absolute,绝对定位,元素相对于当前父元素进行定位。fixed,固定定位,元素相对于浏览器页面窗口进行定位

1 static

static 默认值,无定位,不能当作绝对定位的参照物,并且设置标签对象的left、top等值是不起作用的的。

2  position: relative/absolute

    relative 相对定位。相对定位是相对于该元素在文档流中的原始位置,即以自己原始位置为参照物。有趣的是,即使设定了元素的相对定位以及偏移值,元素还占有着原来的位置,即占据文档流空间。对象遵循正常文档流,但将依据top,right,bottom,left等属性在正常文档流中偏移位置。而其层叠通过z-index属性定义。

注意:position:relative的一个主要用法:方便绝对定位元素找到参照物。

    absolute 绝对定位。

定义:设置为绝对定位的元素框从文档流完全删除,并相对于最近的已定位祖先元素定位,如果元素没有已定位的祖先元素,那么它的位置相对于最初的包含块(即body元素)。元素原先在正常文档流中所占的空间会关闭,就好像该元素原来不存在一样。元素定位后生成一个块级框,而不论原来它在正常流中生成何种类型的框。

重点:如果父级设置了position属性,例如position:relative;,那么子元素就会以父级的左上角为原始点进行定位。这样能很好的解决自适应网站的标签偏离问题,即父级为自适应的,那我子元素就设置position:absolute;父元素设置position:relative;,然后Top、Right、Bottom、Left用百分比宽度表示。

另外,对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。

总结:参照物用相对定位,子元素用绝对定位,并且保证相对定位参照物不会偏移即可。

3  position:fixed

fixed:对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性 定义。 注意点: 一个元素若设置了 position:absolute | fixed; 则该元素就不能设置float。这 是一个常识性的知识点,因为这是两个不同的流,一个是浮动流,另一个是“定位流”。但是 relative 却可以。因为它原本所占的空间仍然占据文档流。

在理论上,被设置为fixed的元素会被定位于浏览器窗口的一个指定坐标,不论窗口是否滚动,它都会固定在这个位置。

仅使用margin属性布局绝对定位元素

此情况,margin-bottom 和margin-right的值不再对文档流中的元素产生影响,因为该元素已经脱离了文档流。另外,不管它的祖先元素有没有定位,都是以文档流中原来所在的位置上偏移参照物。  
  图9中,使用margin属性布局相对定位元素。
  层级关系为:
  <div ——————————— position:relative;
  <div—————————-没有设置为定位元素,不是参照物
  <div———————-没有设置为定位元素,不是参照物
  <div box1
  <div box2 ——–position:absolute; margin-top:50px; margin-left:120px;
  <div box3

参考:https://www.cnblogs.com/yuanchenqi/articles/5977825.html

https://www.cnblogs.com/chichung/p/9686982.html

转载于:https://www.cnblogs.com/icemonkey/p/10495053.html

CSS 内外边距 float positio属性相关推荐

  1. 7.css内外边距设置

    1.常用写法总结 常用属性 说明 margin 设置外边距 padding 设置内边距,注意:设置内边距会改变原有容器的大小 2.代码示例 <!DOCTYPE html> <html ...

  2. css边距和填充示例代码,css 内外边距(示例代码)

    一.边距 内边距: 边框于内容之间的距离. 外边距:边框于边框之间的距离. 二.外边距margin Margin的特性 margin始终是透明的. margin通过使用单独的属性,可以对上.右.下.左 ...

  3. html定义盒子距离顶底端像素,css - 盒子内外边距

    css - 边距 元素内边距 内边距是指元素包含的内容离元素边框之间的间距,内边距不能设负值.内边距(padding).(边框)border都会撑大盒子,在浏览器中显示的元素的尺寸可能包含了盒子的pa ...

  4. html之CSS设计(文本、边框、列表标签、display设置、内外边距)

    文章目录 一.文本属性 二.边框属性 三.列表标签 四.display设置 五.内外边距 本篇文章主要介绍CSS设计中的文本属性.边框边距.列表标签.display的几种用法,还有一个最容易被忽视的点 ...

  5. CSS边框、边距、轮廓(边框宽度/颜色/各边/简写属性/圆角边框/内外边距/高度宽度/框模型/轮廓宽度/颜色/属性/偏移)——万字长文|一文搞懂

    目录 CSS边框 CSS 边框属性 CSS 边框样式 实例 CSS 边框宽度 实例 特定边的宽度 实例 CSS 边框颜色 实例 特定边框的颜色 实例 HEX 值 实例 RGB 值 实例 HSL 值 实 ...

  6. css --- [读书笔记] 盒模型(边框、内外边距)

    说明 源代码 学习 盒子模型(css重点) css学习三大重点: css盒子模型. 浮动. 定位 目标: 能说出盒子模型由哪四部分组成: 内容.边框.内外边距 能说出内边距的作用,设置不同数值分别代表 ...

  7. 2021-04-05 web前端CSS之权重,盒子边框内外边距

    视频学习:黑马程序员pink老师 笔记:层叠性 相同选择器给设置相同的样式--如果样式冲突,就近原则 样式不冲突,不会层叠 <!DOCTYPE html> <html lang=&q ...

  8. html盒子左右边框边距,CSS盒子模型、内外边距、边框、行高、背景

    1.盒子模型 所谓盒子模型就是把HTML页面中的元素看作是一个矩形的盒子,也就是一个盛装内容的容器.每个矩形都由元素的内容.内边距(padding).边框(border)和外边距(margin)组成. ...

  9. 清除内外边距(HTML、CSS)

    清除内外边距(HTML.CSS) <!DOCTYPE html> <html lang="en"><head><meta charset= ...

最新文章

  1. CentOS7环境搭建使用PhpStorm上传代码
  2. 面向对象与面向过程区别
  3. SSH 用 top 命令查看 CPU 使用率
  4. 中柏平板触摸驱动_一文总览2019年最新最全的工业平板电脑定制化服务
  5. python celery异步_【Python】Celery异步处理
  6. P4254-[JSOI2008]Blue Mary开公司【李超树】
  7. java线程的创建与执行_Java多线程的创建和运行
  8. jQuery实现多条件筛选
  9. linux内核驱动之 用户空间和内核空间
  10. Windows Server 2016多用户同时登录远程桌面
  11. [整理] mysql操作
  12. jmeter.properties控制聚合报告的用户响应时间设置和smmary results
  13. SiteMesh配置下载使用(简单介绍)
  14. 东鹏特饮占据市场第二的背后:数据让我们比谁都了解消费者!
  15. 量化投资教父爱德华·索普人生路:打败赌场 战胜股市
  16. 桥接模式和装饰者模式的区别
  17. Latex 中如何使插图的位置不跑到开头而紧跟插入的文字后
  18. iOS开发:2017苹果开发者账号申请流程
  19. 2020.5.12第一次博客
  20. airpodspro窃听模式_AirPodsPro怎么切换模式

热门文章

  1. mmorpg游戏第2次内测问题总结
  2. CentOS6 安装gcc编译器,解决【configure: error: no acceptable C compiler found in $PATH】问题
  3. java中使用tika_【Tika基础教程之中的一个】Tika基础教程
  4. 直流无刷电机c语言程序,无位置传感器的直流无刷电机调速控制程序(一)
  5. 弹出框PopuoWindow
  6. ld链接时提示接口未实现_苹果耳机一分二转接口,可以边听歌边充电!
  7. 编辑审稿时不会从头看到尾!所以论文应该这样写……
  8. python定义公民类_Python-理解函数为”一等公民”
  9. 做什么网站挣钱,这几种类型的网站可能适合你!
  10. 《一个人的朝圣》—— 读后总结