让css初学者抓狂的属性float
挣扎了好久,始终没有决定要不要写博客,心里有几个顾虑一是我是小白,我写的文章有没有人看?二是我是小白,我写的文章假如存在诸多错误,理解的不对发表上去再去误导别人。三是写一篇文章费时费力。但是我现在想明白了,我不写技术大牛的文章,就写菜鸟的学习型文章。我写文章是为了我自己,不是为了别人。有错误正好别人提出改正。
写文章有几个好处,一来可以理清思绪,对于我这个思维混乱的人来说是再好不过的方法了,二来可以记录学习知识,方便以后忘记了可以回来看看。三是已积累起来的文章可以让自己很有成就感。
文章多是学习别人文章的总结和自己的个人见解,所以实际上有些认识可能是不准确的,欢迎大神们指点,也欢迎交流。
Float属性是css必会属性之一,但是它看上去简单,却有很深的奥义。看了张鑫旭的两篇文章,对于float的理解提高了一个层次。
http://www.zhangxinxu.com/wordpress/?p=583 CSS float浮动的深入研究、详解及拓展(一)
http://www.zhangxinxu.com/wordpress/?p=594 CSS float浮动的深入研究、详解及拓展(二)
以下是我对于他的文章写的个人总结和一些认识。
再讲float属性之前,必须要知道高度的概念和display:inline-block的包裹性
高度由两个css模型产生:
一个是box模型(content的height+padding+margin),这个是最基础的大家应该都是知道;
一个是line box模型(line-height,内部的最高部分决定),这个里面就很深奥,让我学习了一番。
还要说一下display:inline-block的包裹性,即设置了这个属性,该元素拥有block的属性可以设置宽和高了,也用拥有了行内元素的属性,宽和高将根据内容自适应。这里强调的是他后面的属性根据内容自适应宽和高的特性。
一般情况下一个块级元素,没有设置display:inline-block这个属性,元素也没有设置宽度的话,元素的宽应该是继承父元素的宽度,如果是行内元素,没有设置display:inline-block这个属性,它的宽度和高度是由内容自适应,但是设置高度和宽度是不管用的。
display:inline-block结合了行内和块级元素,你不设置宽高,我就按内容自适应,你设置了我就按你设置的走。
那么下面我们来说浮动(float)
一、浮动的本质是用来文字环绕的,像分栏布局和列表排列都可用其它属性实现。
二、浮动是一个带有方位的display:inline-block;所以设置浮动,就会有默认的display:inline-block;这个属性。不需要再写display了;设置display:inline-block带来的各种效果,比如高宽自适应而不是继承父元素宽。可以设置高和宽。他的前后不会像块级元素默认换行(但是它没有高度)。
三、浮动会破坏inline-box,产生两个结果。①(无inlinebox->无line-box->无高度)。②图片与文字无法同行显示。这两个结果恰恰是文字环绕的所必需的。
实践与解释
文字多了,你看就是所谓的环绕效果吧
Float:left|right;与position:absolute;的一些区别
Float:left|right;属性与position:absolute属性都具有包裹性,两者都会使元素脱离文档流,但是,与absolute不同的是:float 的元素还会在文档流上占据一个位置。position:absolute的元素是根据最近的非static的父元素定位,如果没有,则根据最初的包含块定义(一般是body),关于float,也会脱离文档流,会被放置在其容器的左边或右边。
关于下列问题
1关于li标签水平排列等一系列float应用及原理
2浮动会破坏自己,影响别人
①
浮动产生bug的原因
②
清楚浮动的方法与本质
3浮动布局的替代效果
还没有具体学习等学习之后再好好总结。
让css初学者抓狂的属性float的更多相关文章
- CSS传统布局之display属性+float属性+position属性
这三个属性是传统网页布局中经常用到的属性. 读这篇文章之前,希望你对css布局模型已经有了一定的了解.因为本文的三个属性是和css三个布局模型紧密联系在一起的.因此,如若你并不了解,我推荐你先看一下c ...
- DIV+CSS:Margin和Padding属性[转载]
margin和padding用来隔开元素,margin是隔开元素与外边,padding是隔开元素里边. margin: 包括margin-top.margin-right.margin-bottom. ...
- CSS和JavaScript标签style属性对照表
CSS和JavaScript标签style属性对照表一般情况是把"-"去掉,后面字母用大写. CSS语法 (不区分大小写) JavaScript语法 (区分大小写) border ...
- [转]图解CSS的padding,margin,border属性(详细介绍及举例说明)
图解CSS的padding,margin,border属性 W3C组织建议把所有网页上的对像都放在一个盒(box)中,设计师可以通过创建定义来控制这个盒的属性,这些对像包括段落.列表.标题.图片以及层 ...
- 图解CSS的padding,margin,border属性(详细介绍及举例说明)
图解CSS的padding,margin,border属性 W3C组织建议把所有网页上的对像都放在一个盒(box)中,设计师可以通过创建定义来控制这个盒的属性,这些对像包括段落.列表.标题.图片以及层 ...
- C#使用CSS选择器抓取页面内容
最近在查wpf绘图资料时,偶然看到Python使用CSS选择器抓取网页的功能.觉得很强,这里用C#也实现一下. 先介绍一下CSS选择器 在 CSS 中,选择器是一种模式,用于选择需要添加样式的元素. ...
- css3系列-2.css中常见的样式属性和值
css3系列-2.css中常见的样式属性和值 继续上一篇文章的继续了解css的基础知识,关注我微信公众号:全栈学习笔记 css中常见的样式属性和值 字体与颜色 背景属性 文本属性 边框属性 内外边距 ...
- 使用Google产品以来遇到的最糟糕、最霸道、最让人抓狂的设计
很久没有登录cnblogs@gmail.com这个邮箱,今天通过gmail.com登录了一下,登录后出现一个对话框要求设置性别与出生日期,而且必须要设置,不设置不让登录. 这个邮箱是我们网站用的是邮箱 ...
- css字体样式(Font Style),属性
css字体样式(Font Style),属性 css字体样式(Font Style)是网页中不可或缺的样式属性之一,有了字体样式,我们的网页才能变得更加美观,因此字体样式属性也就成为了每一位设计者 ...
随机推荐
- java对象的序列化与反序列化使用
1.Java序列化与反序列化 Java序列化是指把Java对象转换为字节序列的过程:而Java反序列化是指把字节序列恢复为Java对象的过程. 2.为什么需要序列化与反序列化 我们知道,当两个进程进 ...
- symfony中twig的模板载入
模板 载入模板 {% include ‘sidebar.html’ %} 当前模板的变量也会传递到 被include的模板里,在那里面可以直接访问你这个模板的变量. {% for comment in ...
- Android 5.1 - 状态栏充电标志问题
Android 5.1 Ubuntu14.04 SourceInsigh 电量已满,插着USB头,观察Settings - Battery,电量为100%,状态为full,但仍有充电图标rust 之 ...
- 单利 复利计算器程序1.0 2.0 3.0 [ 合 ] 之 C语言
本程序用C语言编写~~~ 1.计算:本金为100万,利率或者投资回报率为3%,投资年限为30年,那么,30年后所获得的利息收入:按复利计算公式来计算就是:1,000,000×(1+3%)^30 1 v ...
- Ibatis的简单介绍
定义: 相对Hibernate和Apache OJB 等“一站式”ORM解决方案而言,ibatis 是一种“半自动化”的ORM实现.以前ORM的框架(hibernate,ojb)的局限: 1. 系统的 ...
- Borg Maze 分类: POJ 2015-07-27 15:28 5人阅读 评论(0) 收藏
Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9971 Accepted: 3347 Description The B ...
- .Net neatupload上传控件实现文件上传的进度条
1. 引入bin文件 (可以到neatupload官网下载,也可以到教育厅申报系统中找) 2. 将控件加入到工具栏,在工具栏中点鼠标右键,如图: 3. 加入neatuplaod这个文件夹(可以到nea ...
- linux socket高性能服务器处理框架
这个博客很多东西 http://blog.csdn.net/luozhonghua2014/article/details/37041765 思考一种高性能的服务器处理框架 1.首先需要一个内存池 ...
- http模式
http遵守请求响应模式: 请求: 请求行:HTTP方法-请求的URL-HTTP版本 请求行 空行 消息体 响应: 状态行:HTTP版本-响应码-响应描述 响应头 空行 消息体 其他的重点: http ...
- nautilus-open-terminal很有用的插件--鼠标右键打开终端
1.1fedora安装# yum -y install nautilus-open-terminal安装nautilus-open-terminal,注销下X桌面即可ubuntu安装#sudo apt ...