前言

这篇是在慕课网上跟着张鑫旭重走CSS之路的第三篇学习笔记了,主要是学习float属性,闲话少说,下面进入正文.

float的历史

要想了解一个东西,我们还是需要从本质去了解它,那么我们就需要问一个直抵本质的问题:float被设计出来是干嘛的? 答案是:实现文字环绕效果.对,就是这么简单因为这个属性是在很久很久以前就有了,那个时候是没有那么多炫酷的CSS效果的,所以这个属性设计的初衷很简单,就是实现文字环绕.

float的特性

我们知道float的特性有两个,一个是包裹,一个就是破坏.下面就主要讲讲这两个特性

包裹

包括有以下三种行为,收缩/坚挺/隔绝,简而言之就是把一个元素包裹起来,类似在外面套一个盒子一样,将其与其它页面元素隔离开来.又成BFC(块级格式化上下文)

破坏

所谓的破坏性是指,当一个子元素应用浮动属性后,可能会导致父元素高度塌陷,这个就是我们常说的浮动的破坏性.

另外需要强调的是,这种特性不是bug,而是CSS规范,这是因为浮动的只是为了实现文字环绕效果,当初设计的时候,就是应用了破坏性,当元素应用浮动时,包裹它的元素因破坏性塌陷,从而导致文字环绕到元素周围.

清除浮动

清除浮动主要是从以下两方面入手:

  • 在父元素底部插入 有 clear:both声明的元素;
  • 依然与外部元素有连接,比如,依然有margin重叠.

常用形式有以下两种:

l  HTML block水平元素底部插入

这样会导致很多无意义的div元素

l  CSS after 伪类元素底部生成

对低版本的IE浏览器不友好.

父元素 BFC(高级浏览器)或者haslayout(IE)

相当于将元素与其它元素完全隔绝开来.

这个方法也是无法实现多浏览器支持的.低版本的IE浏览器可以使用 zoom:1.

针对清楚浮动,比较合理的做法是

高版本浏览器使用

.clearfix{ display;block;height:0,clear:both;overflow:hidden}或者

.clearfix :after{display : table; clear:both}

IE6/7可以使用

.clearfix{ *zomm:1}

Tips:clearfix 只应该应用在包含浮动子元素的父级元素上,乱用的话可能会导致低版本的浏览器效果无法预知

浮动的应用

浮动元素的block块状化

破坏性造成的紧密排列特性(去空格)

以上两个特性是我们可以在日常的写CSS的时候加以利用的特性,比如,利用这个特性和用户写一些需要紧密排列的元素的页面布局.

缺点:

1 容错性很差,无法自试用布局

2.无法重用,因为需要设置固定的宽度高度,所以重用性很差

浮动与流体布局

1.单侧固定

左侧固定元素应用 :width+float

右侧文字应用padding-left/margin-left

这个是最基本的浮动应用了,标准的浮动,相当于文字样式margin/padding:0 样式,当给环绕元素加上padding/margin时,那么环绕元素将不会继续在浮动元素下面展示,而是在其一侧对齐

2.右边固定,左侧自适应

基本可以跟上面所说的描述相反即可,但是需要注意的是,浮动在右边的元素是需要在页面中放到左边元素的前面,这个是跟我直观感受相反的一点.

那怎么样才能在页面元素前后顺序一致的时候实现右侧固定左侧自适应布局呢?这里就要用到我们上面刚刚说过的浮动的块状化和紧密排列特性了.具体来说就是.左侧环绕元素和固定宽度元素都使用flat:left布局,然后左侧宽度100%这个时候会把固定布局的元素挤到下一行去,这个时候我们需要给固定布局的元素叫一个负值的margin,让它回到我们希望的位置.这个时候环绕的问文字右侧浮动元素遮挡,那我们可以使用一个子元素包裹所有环绕文字,并给它加一个margin/padding.

简而言之,就是:

环绕父 元素: width:100%+float

环绕子元素: padding/margin

右侧固定元素 width+float+marginf负值

3.智能自适应

固定套路

一侧浮动,另一侧使用display:table-cell(ie8+)/inline-block(ie7)

兼容性

主要是IE7上的一些问题了,表示已放弃IE7,只当是思路学习了.

外链:

http://www.imooc.com/learn/121

Css深入理解之浮动_慕课网课程笔记的更多相关文章

  1. Css定位之relative_慕课网课程笔记

    前言 最近在慕课网上跟着张鑫旭大神重新学习一遍CSS相关的知识,以下是学习的笔记以及个人一些理解 relative对绝对定位的限制 1.限制绝对定位 绝对定位的top.left.right和botto ...

  2. Float浮动(慕课网学习笔记)

    float浮动 属性:值 意义 float:left 左浮动 float:right 右浮动 float:none 不浮动 float:inherit 继承父元素浮动属性,若父元素没有浮动属性则失效 ...

  3. Css定位之absolute_慕课网课程笔记

    absolute和float 绝对定位和浮动有相似之处,即都有破坏性和包裹性,破坏性是指其会导致包裹自身的复原塌陷,包裹性是float的天赋技能,对于绝对定位来说,其会包括子元素 越独立越强大 1.去 ...

  4. 网站优化之-SEO在网页制作中的应用(信息来自慕课网课程笔记)

    一.SEO基本介绍. 1.搜索引擎工作原理. 2.seo简介:SEarch Engine Optimization,搜索引擎优化.为了提升网页在搜索引擎自然搜索结果中的收录数量及排序位置而做的优化行为 ...

  5. Node.js爬虫-爬取慕课网课程信息

    第一次学习Node.js爬虫,所以这时一个简单的爬虫,Node.js的好处就是可以并发的执行 这个爬虫主要就是获取慕课网的课程信息,并把获得的信息存储到一个文件中,其中要用到cheerio库,它可以让 ...

  6. PHP消息队列实现及应用_慕课网学习

    https://blog.csdn.net/d_g_h/article/details/79643714 https://blog.csdn.net/tTU1EvLDeLFq5btqiK/articl ...

  7. 安卓开发_慕课网_Fragment实现Tab(App主界面)

    学习内容来自“慕课网” 这里用Fragment来实现APP主界面 思路: 底部横向排列4个LinearLayout,每个LinearLayout包含一个图片按钮和一个文字 1.默认显示第一个功能(微信 ...

  8. 安卓开发_慕课网_ViewPager与FragmentPagerAdapter实现Tab实现Tab(App主界面)

    学习内容来自“慕课网” ViewPager与FragmentPagerAdapter实现Tab 将这两种实现Tab的方法结合起来.效果就是可以拖动内容区域来改变相应的功能图标亮暗 思路: Fragme ...

  9. 安卓开发_慕课网_ViewPager实现Tab(App主界面)

    学习内容来自“慕课网” 网站上一共有4种方法来实现APP主界面的TAB方法 这里学习第一种 ViewPager实现Tab 布局文件有7个, 主界面acitivity.layout <Linear ...

随机推荐

  1. 非常详细的/etc/passwd解释

    root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nol ...

  2. [USACO] 铺放矩形块 题解

    题目大意: 给定4个矩形块,找出一个最小的封闭矩形将这4个矩形块放入,但不得相互重叠.所谓最小矩形指该矩形面积最小. 思路: 枚举矩形的安放顺序,再按照题目所给的图判断即可,主要要想到枚举. 代码: ...

  3. Shader实例:边缘发光和描边

    效果图: 1.边缘发光 思路:用视方向和法线方向点乘,模型越边缘的地方,它的法线和视方向越接近90度.点乘越接近0 那么用 1-减去上面点乘的结果,来作为颜色分量,来反映边缘颜色强弱. Shader ...

  4. 聊下并发和Tomcat线程数(错误更正)

    本文前半部分结论存在严重错误,请看最后2015-1-20更新部分. 最近一直在解决线上一个问题,表现是: Tomcat每到凌晨会有一个高峰,峰值的并发达到了3000以上,最后的结果是Tomcat线程池 ...

  5. JavaScript 一种轻量级的编程语言

     JavaScript 一种轻量级的编程语言 作为一名计算机应用专业的学生,大一上学期开始接触了网页设计和制作,刚开始时感觉做网页很不错,简单地写几行代码就能做出效果来,当时感觉很兴奋,渐渐的喜欢上它 ...

  6. HTML 5 音频(audio)

     audio 元素支持三种音频格式 IE 9 Firefox 3.5 Opera 10.5 Chrome 3.0 Safari 3.0 Ogg Vorbis   √ √ √   MP3 √     √ ...

  7. O(n) 筛法求素数

    var tot,i,j,k,m,n:longint; prime:array[0..100000] of boolean; p:array[0..100000] of longint;begin re ...

  8. 【emWin】例程七:绘制基本图形

    简介:emWin 包含完整的2-D 图形库,可供大多数应用程序充分使用 本例程介绍如何使用图形API绘制基本的2-D图形 实验指导书及代码包下载: 链接:http://pan.baidu.com/s/ ...

  9. DevOps is dirty work - What's the deal

    什么是DevOps?终于又回到这个最初的问题. 第一次看到这个词的时候,还身陷于各种敏捷概念轰炸中.用“身陷”这个词其实并不准确,因为那个年代的我也是那些热情洋溢地无处不宣传敏捷的热血文艺青年中的一员 ...

  10. 再谈java两种变量(基本类型和引用类型)(综合各路大神)

    基本类型: 基本类型自然不用说了,它的值就是一个数字,一个字符或一个布尔值. int  a:   a=250: //声明变量a的同时,系统给a分配了数据空间. 引用类型: 是一个对象类型,值是什么呢? ...