<!-- 《CSS世界》 张鑫旭著 -->

min-width/max-width和min-height/max-height

min-width/max-width出现的场景一定是自适应布局或者流体布局中;

max-width和max-height的初始值是none,min-width和min-height的初始值是auto。

如果max-width的初始值是auto,自然会使用和width一样的渲染解析规则,此时max-width的计算值应该是父元素的宽度值,也就是子元素的宽度永远不会比父元素大了,这显然是有问题的;

而如果min-width的初始值是0,那么当我们设置transition过渡同时改变了min-width值,就应该有动画效果,实际上并没有。我们需要手动设置min-width:0,才会出现动画。

min-width/max-width和min-height/max-height属性间,以及与width和height之间有一套相互覆盖的原则:

超越 !important,超越最大。

超越 !important指的是max-width会覆盖width,而且是超越覆盖,就是即便是拥有!important权重的width属性声明也会被max-width覆盖,举个例子:

<img src="1.png" style="width: 480px!important;">
img {max-width: 256px; }

图片最后的呈现宽度是256px。

超越最大指的是min-width会覆盖max-width,此规则发生在min-width和max-width冲突的时候。

任意高度元素的展开收起动画技术

用css来实现展开收起的动画效果,很多时候,我们展开的元素的内容是动态的,也就是高度是不固定的,这时候不妨试试max-height,css代码如下:

.element {
max-height:;
overflow: hidden;
transition: max-height .2s;
}
.element.active {
max-height: 666px;
}

其中展开后的max-height值,我们只需要设定为保证比展开内容高度大的值就可以。但是,如果max-height值太大,在收起的时候可能会有“效果延迟”的问题。因此,建议max-height使用足够安全的最小值。

内联元素

哪些元素是内联元素

这里的“内联”特指“外在盒子”,inline-block和inline-table都是“内联元素”,因为它们的“外在盒子”都是内联盒子。display:inline的元素也是“内联元素”

内联盒模型

(1)内容区域

内容区域指一种围绕文字看不见的盒子,其大小仅受字符本身特性控制,本质上是一个字符盒子(character box);但有些元素,如图片这样的替换元素,其内容显然不是文字,不存在字符盒子之类的,因为对于这类元素来说,内容区域可以看成元素自身。

实际上,内容区域没有明确的定义,所以将其理解成em盒(em-box,可看成是中文字符占据的1em高度区域)也是可以的。

(2)内联盒子(inline box)。

内联盒子和匿名内联盒子

如果外部含内联标签(<span>、<a>等),则属于“内联盒子”;

如果是光秃秃的文字,则属于“匿名内联盒子”;

并不是所有光秃秃的文字都是“匿名内联盒子”,也可能是“匿名块级盒子”,关键要看前后的标签是内联还是块级。

这里前后的标签我理解的是兄弟元素,如果光秃秃的文字前后都是块级元素,那么就是“匿名块级盒子”,不知道理解的对不对。。

(3)行框盒子

每一行就是一个“行框盒子”,每个“行框盒子”又是由一个个“内联盒子”组成的。

(4)包含盒子(containing box)

此盒子由一行一行的“行框盒子”组成。更准确的称呼是“包含块”。

幽灵空白节点

“幽灵空白节点”实际上也是一个盒子,不过是个假想盒,名叫“strut”,中文直译为“支柱”,是一个存在于每个“行框盒子”前面,同时具有该元素的字体和行高属性的0宽度的内联盒。

这里有一个前提,文档声明必须是HTML5文档声明,如果还是很多年前的老声明,则不存在“幽灵空白节点”。

明白“幽灵空白节点”的存在是理解后续很多内联元素为何会这么表现的基础。

《CSS世界》读书笔记(六)的更多相关文章

  1. CSS揭秘读书笔记 (一)

    CSS揭秘读书笔记      (一) 一.半透明边框 要想实现半透明边框可以使用border: border: 10px  solid  hsla(0,0%,100%,.5); background: ...

  2. 《CSS世界》笔记二:盒模型四大家族

    上一篇:<CSS世界>笔记一:流/元素/尺寸下一篇:<CSS世界>笔记三:内联元素与对齐 写在前面 在读<CSS世界>第四章之前,粗浅的认为盒模型无非是margin ...

  3. 《精通CSS》读书笔记(一)

    最近新添16本书,目前开始看陈剑瓯翻译的<精通CSS——高级Web标准解决方案>(Andy Budd, CSS Mastery -- Advanced Web Standards Solu ...

  4. 《css世界》笔记之流、元素与基本尺寸

    1. 块级元素 基本特性:就是一个水平流上只能单独显示一个元素,多个块级元素则换行显示. 块级元素和"display 为block 的元素"不是一个概念,display:list- ...

  5. css 揭秘-读书笔记

    css 揭秘 [希]Lea verou 著 css 魔法 译 该书涵盖7大主题,47个css技巧,是css进阶必备书籍,开阔思路,探寻更优雅的解决方案.这本书完全用css渲染出的html写成的(布局. ...

  6. 《Two Days DIV + CSS》读书笔记——CSS选择器

    1.1.2 CSS选择器 CSS 选择器最基本的有四种:标签选择器.ID 选择器.类选择器.通用选择器. [标签选择器] 一个完整的 HTML 页面由很多不同的标签组成,而标签选择器,则是决定哪些标签 ...

  7. 《Two Days DIV + CSS》读书笔记——CSS控制页面方式

    1.1 你必须知道的知识 (其中包括1.1.1 DIV + CSS的叫法解释:1.1.2 DIV + CSS 名字的误区:以及1.1.3 W3C简介.由于只是背景知识,跳过该章.) 1.2 你必须掌握 ...

  8. spring揭秘 读书笔记 六 bean的一生

    我们知道,Spring容器具有对象的BeanDefinition来保存该对象实例化时需要的数据. 对象通过container.getBean()方法是才会初始化该对象. BeanFactory 我们知 ...

  9. CSS Grid 读书笔记

    基本概念 MDN上的解释是这样的 CSS Grid Layout excels at dividing a page into major regions or defining the relati ...

  10. css揭秘读书笔记

    currentColor属性让hr和段落相同的颜色: div { color: red; } hr { background: currentColor; /* 一定要设置高度*/ height: 0 ...

随机推荐

  1. 一种隐蔽性较高的Java ConcurrentModificationException异常场景

    前言 在使用Iterator遍历容器类的过程中,如果对容器的内容进行增加和删除,就会出现ConcurrentModificationException异常.该异常的分析和解决方案详见博文<Jav ...

  2. ASP.NET MVC+BUI实现表格的操作

    在Web中基于表格的操作,比如添加行.单元格内容编辑等等功能,是完全基于js实现的.但如果程序员完全使用js或者jquery去编写表格控件,则会导致样式不统一,代码量较大等问题,尤其对于不太熟悉js的 ...

  3. ubuntu 14.04 安装python包psycopg2

    http://stackoverflow.com/questions/28253681/you-need-to-install-postgresql-server-dev-x-y-for-buildi ...

  4. threding模块的其他用法

    import threading import time def func(n): time.sleep(0.5) n += 1 print(n, threading.current_thread() ...

  5. 接口自动化测试 (三)request.post

    上一节介绍了  requests.get()  方法的基本使用,本节介绍  requests.post()  方法的使用: 本文目录: 一.方法定义 二.post方法简单使用 1.带数据的post 2 ...

  6. springmvc02,使用注解

    unit04_01 a.RequestMappingHandlerMapping组件 @RequestMapping("/login.do") 该标记用在Controller业务方 ...

  7. jsp标签jstl和el表达式

    1.el表达式的使用 1)访问bean的属性 方式一: ${user.name},容器会依次从pageContext,request,session,application中查找(getAttribu ...

  8. linux中几个热键

    重要的几个热键[Tab],[ctrl]-c, [ctrl]-d  [Tab]按键---具有『命令补全』不『档案补齐』的功能 [Ctrl]-c按键---让当前的程序『停掉』 [Ctrl]-d按键---通 ...

  9. C#压缩图片时保留原始的Exif信息

    啥是Exif信息,有啥用,百度百科有解释: Exif百科 总之,这东西对摄影爱好者来说是不可或缺的,通常使用Photoshop来压缩只要不是保存为Web格式都会保留Exif信息. 而我们写代码来压缩图 ...

  10. AE实现拖拽

    http://edndoc.esri.com/arcobjects/9.2/net/63391c82-c2e6-4797-b2e6-2c1d92f56f44.htm http://help.arcgi ...