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

替换元素和非替换元素的距离有多远?

观点1:替换元素和非替换元素之间只隔了一个src属性!

在Firefox浏览器下,没有src属性的<img>表现和普通<span>类似,已经完全不是替换元素了。很好地证明了“如果图片没有替换内容,图片就是一个普通的内联标签”。、

Chrome浏览器其实有类似的表现,只是需要特定的条件触发,这个条件就是需要有不为空的alt属性值。例如:<img alt="任意值">。

上面两点都可以通过下面的css样式来验证:

img {
display: block;
outline: 1px solid;
}

我们会发现这个<img>宽度是100%于容器。

为何IE浏览器没有src属性的<img>还是替换元素呢?原因在于IE浏览器有个默认的占位替换内容,当src属性缺失时,会使用这个默认的占位内容,这也是IE浏览器下默认<img>尺寸是28×30而不像Chrome浏览器那样为0×0的原因所在。在高版本IE浏览器下,这个占位的替换内容似乎做了透明处理,但是在原生的IE8浏览器下,这个占位内容却全然暴露了。

另一个很好地证明“替换元素和非替换元素区别就在于src属性”的点是“基于伪元素的图片内容生成技术”,详见http://demo.cssworld.cn/4/1-2.php

从这个例子中可以看到图片src没有的时候,::before和::after可以生效,我们可以把alt属性值通过content属性呈现出来。当我们点击按钮给图片添加src地址时,图片变成了替换元素,原先都还支持的::before和::after此时全部无效,此时再hover图片,是不会有任何信息出现的。于是非常巧妙地增强了图片还没加载时的信息展示体验。

但是这种技术支持是有限制的。首先是兼容性问题,目前Chrome和Firefox等浏览器支持,IE浏览器不支持;其次,要想让Chrome和Firefox等浏览器生效,还有一些需要注意的技术点:

(1)不能使用content属性生成图片(针对chrome)

(2)需要alt属性并有值(针对chrome)

(3)不能有src属性(证明观点的关键所在)

(4)Firefox下,::before伪元素的content值会被无视,::after无此问题,应该与Firefox自己占用了::before伪元素的content属性有关。

观点2:替换元素和非替换元素之间只隔了一个CSS content属性

在Chrome浏览器下,所有元素都支持content属性,而其他浏览器仅在::before和::after伪元素中才有支持。

前面已经证明了没有src属性的<img>是非替换元素,但是如果我们用content属性给它生成一张图片,我们就会发现它和有src属性时的视觉效果一模一样。

img { content: url(1.jpg); }
<img>

如果图片原先有src地址,我们也可以使用content属性把图片内容置换掉,于是我们就能轻松实现hover图片变成另外一张图片的效果。例如:

<img src="laugh.png">
img:hover {
content: url(laugh-tear.png);
}

实例地址:http://demo.cssworld.cn/4/1-4.php

但是content属性改变的仅仅是视觉呈现,当我们以右键或其他形式保存这张图片时,所保存的还是原先src对应的图片。

content与替换元素关系剖析

我们把content属性生成的对象称为“匿名替换元素”。

content元素生成的内容都是替换元素。

content属性生成的内容和普通元素内容有很多不同的特性表现:

(1)content生成的文本是无法选中、无法复制的,同时无法被屏幕阅读设备读取,也无法被搜索引擎抓取

(2)不能左右:empty伪类。:empty是一个CSS选择器,当元素里面无内容的时候进行匹配。

(3)content动态生成值无法获取。

.total::after{
content: counter(icecream);
}

getComputedStyle方法可以获得计算样式,但是在这里得到的支持纯粹的content在CSS文件中的属性值。例如:

 var dom = document.querySelector(".total");
console.log(window.getComputedStyle(dom,"::after").content);

得到的是“counter(icecream)”,而不是具体的数值。

等等……

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

  1. 《Android源代码设计模式解析与实战》读书笔记(十七)

    第十七章.中介者模式 中介者模式也称为调解者模式或调停者模式,是一种行为型模式. 1.定义 中介者模式包装了一系列对象相互作用的方式.使得这些对象不必相互明显作用.从而使它们能够松散耦合.当某些对象之 ...

  2. 《Android源代码设计模式解析与实战》读书笔记(十四)

    第十四章.迭代器模式 迭代器模式,又叫做游标模式.是行为型设计模式之中的一个.我们知道对容器对象的訪问必定会涉及遍历算法.我们能够将遍历的方法封装在容器中,或者不提供遍历方法,让使用容器的人自己去实现 ...

  3. 《Android源代码设计模式解析与实战》读书笔记(十)

    第十章.解释器模式 解释器模式是一种用的比較少的行为型模式.其提供了一种解释语言的语法或表达式的方式. 可是它的使用场景确实非常广泛,仅仅是由于我们自己非常少回去构造一个语言的文法,所以使用较少. 1 ...

  4. 《Android源代码设计模式解析与实战》读书笔记(二十)

    第二十章.适配器模式 适配器模式是结构型设计模式之中的一个,它在我们的开发中使用率极高,比方ListView.GridView以及RecyclerView都须要使用Adapter. 1.定义 适配器模 ...

  5. 《Android源代码设计模式解析与实战》读书笔记(十八)

    第十八章.代理模式 代理模式也称托付模式,是结构型设计模式之中的一个.是应用广泛的模式之中的一个. 1.定义 为其它对象提供一种代理以控制对这个对象的訪问. 2.使用场景 当无法或不想直接訪问某个对象 ...

  6. 《Android源代码设计模式解析与实战》读书笔记

    1.定义 将对象组合成树形结构以表示"部分-总体"的层次结构,使得用户对单个对象和组合对象的使用具有一致性. 2.使用场景 (1)表示对象的部分-总体层次结构时. (2)从一个总体 ...

  7. 《Android源代码设计模式解析与实战》读书笔记(八)

    第八章.状态模式 1.定义 状态模式中的行为是由状态来决定,不同的状态下有不同的行为.当一个对象的内在状态改变时同意改变其行为,这个对象看起来像是改变了其类. 2.使用场景 1.一个对象的行为取决于它 ...

  8. 《Android源代码设计模式解析》读书笔记——Android中你应该知道的设计模式

    断断续续的,<Android源代码设计模式解析>也看了一遍.书中提到了非常多的设计模式.可是有部分在开发中见到的几率非常小,所以掌握不了也没有太大影响. 我认为这本书的最大价值有两点,一个 ...

  9. R语言实战读书笔记(八)回归

    简单线性:用一个量化验的解释变量预测一个量化的响应变量 多项式:用一个量化的解决变量预测一个量化的响应变量,模型的关系是n阶多项式 多元线性:用两个或多个量化的解释变量预测一个量化的响应变量 多变量: ...

  10. iPhone与iPad开发实战读书笔记

    iPhone开发一些读书笔记 手机应用分类1.教育工具2.生活工具3.社交应用4.定位工具5.游戏6.报纸和杂志的阅读器7.移动办公应用8.财经工具9.手机购物应用10.风景区相关应用11.旅游相关的 ...

随机推荐

  1. SpringBoot------连接MySQL报错:The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized

    报错提示: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more than one time zon ...

  2. CentOS 7下安装samba

    Samba是一种软件,它可以运行在非Windows平台上,比如UNIX, Linux, IBM System 390, OpenVMS或其他操作系统.Samba使用安装在主机上的TCP/IP协议.当正 ...

  3. MFMailComposeViewController发送邮件的实例

    本文转载至 http://blog.csdn.net/liufeng520/article/details/7585140   iPhone API已经提供了系统写邮件界面的接口,使用MFMailCo ...

  4. MonoDevelop ctrl + ' 不能定位正确的unity文档

    Just Do This I had the same problem in MonoDevalop, but the url in it cannot be changed. So I tried ...

  5. 后渗透神器Empire的简单使用

    1.安装 1.1.系统环境: Debian系Linux:例如Ubuntu和Kali(本文使用Kali作为环境) 1.2.安装命令: 安装最后需要输入用户名.密码 wget https://raw.gi ...

  6. codeforces R 493 div2

    我蓝了!蓝了!!!蒟蒻的蓝色.日常点开friend发现竟然没几个人打??然后去div1看了一下果然学长全都去打div1了呜呜呜. 看到了久违的黄大仙,以为他今晚要上grandmaster,结果打完发现 ...

  7. MUI - 复选框、单选框、使用js获取选择值

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...

  8. Python学习之旅(一)

    Python的简介 Python是一种面向对象的.动态的脚本语言,可用来设计网页和开发后台功能.其创始人Guido van Rossum于1989年圣诞节期间创造了这门语言. (图片来自百度) Pyt ...

  9. AJAX----注:借鉴

    Ajax的工作原理. Ajax的核心是JavaScript对象XmlHttpRequest.该对象在Internet Explorer5首次引入,它是一种支持异步请求的技术.简而言之,XmlHttpR ...

  10. Excel GET.CELL说明

    GET是得到的意思CELL是单元格的意思  --->那么它的意思就是你想得到单元格的什么东西(信息)  函数定义:  GET.CELL(类型号,单元格(或范围))  其中类型号,即你想要得到的信 ...