html中为什么用i标签作小图标

发布时间:2021-03-01 10:51:12

来源:亿速云

阅读:75

作者:清风

这篇文章主要为大家展示了html中为什么用i标签作小图标,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“html中为什么用i标签作小图标”这篇文章吧。

html是什么

html的全称为超文本标记语言,它是一种标记语言,包含了一系列标签.通过这些标签可以将网络上的文档格式统一,使分散的Internet资源连接为一个逻辑整体,html文本是由html命令组成的描述性文本,html命令可以说明文字,图形、动画、声音、表格、链接等,主要和css+js配合使用并构建优雅的前端网页。用 元素做图标在语义上是不正确的(虽然看起来像 icon 的缩写);

比 短,但 gzip 后差异很小,不过打字可以少按三个键;

多数图标用的是空 元素,配合 ::before 伪元素实现,因为没有内容,读屏器不会朗读(这样即使有特殊处理也跳过了),机器理解起来应该也没什么影响。

综合来看,从实用性上暂时没看出有什么缺陷,所以目前用不用 取决于你对于遵循规范有多洁癖。

基本语法

:before 和 :after 伪元素编码非常简单(和大多数的css属性一样不需要一大堆的前缀)。这里是一个简单的例子。#example:before {  content: "#";}#example:after {  content: ".";}

这个例子中提到了两件事情,第一,我们用#example:before和#example:after来目标锁定相同的元素.严格的说,在代码中他们是伪元素。

第二,在内容模块中提到,伪元素如果没有设置“content”属性,伪元素是无用的。

在这个例子中,拥有属性id的元素将有一个"哈希符号"放置内容之前,和一个"句号"在内容之后。

语法笔记

你可以设置content属性值为空,并且仅仅把他当做一个内容很少的盒子。像这样:#example:before {  content: "";

display: block;  width: 100px;  height: 100px;}

然而,你不可以完全的移除content属性,如果你移除了,伪元素将不会起作用。至少,content属性需要空引用作为它的值(即:content:“”)。

你也许注意到,你也可以用两个冒号(::before 和 ::after) 写伪元素,这个我以前讨论过的。简短的解释是,对于这两种语法没有什么不同,仅仅一点的不同是,伪元素(双冒号),css3中的伪类是(单冒号)

最后就语法而言。从技术上讲,你可以普遍的应用伪元素,不是放在特殊的元素上,像这样::before {  content: "#";}

虽然上面是有效的,但是它十分的没用。代码会在DOM里的每个元素的内容之前插入散列符号。即使你删除了

标签和它的所有内容,你仍会在页面上看见两个散列符号:一个在里,另一个在标签里,浏览器会自动创建哪一个。

插入内容的特点

正如前面提及的,插入的内容在页面的源码里是不可见的,只能在css里可见。

同时,插入的元素在默认情况下是内联元素(或者,在html5中,在文本语义的类别里)。因此,为了给插入的元素赋予高度,填充,边距等等,你通常必须显式地定义它是一个块级元素。

这会是对如何设计伪元素的一个简要的说明,看我下面文本编辑器的这幅图

在这个例子中,我高亮的样式将被应用到元素里插入到目标元素内容的前面和后面。

还要注意的是典型的CSS继承规则适用于插入的元素。例如,你有字体系列黑体,宋体,无衬线字体应用到body元素里,然后伪元素会像其他元素一样继承这些字体系列。

同样的,伪元素不会继承没有自然继承自父元素(如 padding and margins)的样式。

之前或之后是什么?

你的直觉是:before和:after伪元素可能是 插入的内容会被注入到目标元素的前或后注入?但是,正如上面提到的,不是这样的。

注入的内容将是有关联的目标元素的子元素,content指向的内容会被置于子元素的“前”或“后”。

为了证明这一点,看看下面的代码。首先,在HTML:

Other content.

下面是插入伪元素的css:p.box {

width: 300px;

border: solid 1px white;

padding: 20px;}p.box:before {

content: "#";

border: solid 1px white;

padding: 2px;

margin: 0 10px 0 0;

}

在此html里,你所看的一段文字带有的是一个类的box,还有这样的文字“Other content”在里面(像你所会看到的一样,如果你看见了首页的源代码)。在css中,这段内容被设置了宽度,以及一些padding和可见的边框

然后我们有了伪元素。在这个例子中,它是一个散列符号插入到该段内容之前。随后css给了它一个边框以及一些padding和margins。

这里是浏览器中查看的结果:

外面的盒子是这个段落。围绕有散列符号的边框表示伪元素的边界。所以,不是插入“before”到段落,而是伪元素被置于到此段落的“Other content”的前面。

插入非文本内容

我简要的提醒,你可以把属性的值置为空字符串或是插入文本内容。你基本上有属性的值要包含什么的两个额外的选择

首先,你可以包含一个指向一个图像的URL,就像在css里包含一个背景图像一样做你能做的p:before {  content: url(image.jpg);}

注意不能使用引号。如果你将URL用引号括起来,那么它会变成一个字符串和插入文本“url(image.jpg)”作为其内容,插入的而不是图像本身。

当然,你可以包含一个Data URI代替图像引用,正如你可以用css背景一样。

你还可以选择attr(X)中的函数的形式。此功能,根据规范 ,“把X属性的值以字符串的形式返回”

下面是一个例子:a:after {  content: attr(href);}

attr()函数的功能是什么?它得到特定属性的值并把它作为插入的文本成为一个伪元素。

上面的代码会导致页面上的每一个元素的href值立即被放置在每个各自的元素的后面。在文档被打印时,它可以用作一个包含所有URl的打印样式表。

你也可以用这个函数去获取元素的title属性,或者甚至是microdata的值。当然,并不是所有的例子都符合自己的实际,但根据不同的情况,一个特定的属性值作为一个伪元素可以是实际的。

然而,获取title或者图像的alt的值并作为实际的伪元素显示在页面上是不可能的。记住伪元素必须是被应用元素的子元素。图像,这是void(或者是空元素),没有子元素,所以它在这个列子中不可用,同样也适用于其他空元素,例如:。

可怕的浏览器兼容性

任何前端技术的发展势头,第一个问题就是浏览器的支持。在这种情况之下,它不是个很大的问题。

浏览器支持:before 和 :after 伪元素栈,像这样:Chrome 2+,

Firefox 3.5+ (3.0 had partial support),

Safari 1.3+,

Opera 9.2+,

IE8+ (with some minor bugs),

几乎所有的移动浏览器。

唯一真正的问题是没有获得支持的(不用奇怪)IE6和IE7。所以,如果你的爱好者是在良好合适的web开发(或者其他具有较低IE版本的市场),你可以继续自由地使用伪元素。

伪元素不是决定性的

幸运的是,缺少伪元素不会造成大问题。大多数情况下,伪元素一般修饰(或者帮助)内容,不会给不支持的浏览器造成问题。所以,如果你的支持者具有较高的IE版本,你仍然可以在某种程度上使用它们。

以上就是关于“html中为什么用i标签作小图标”的内容,如果改文章对你有所帮助并觉得写得不错,劳请分享给你的好友一起学习新知识,若想了解更多相关知识内容,请多多关注亿速云行业资讯频道。

html i标签是什么意思,html中为什么用i标签i/i作小图标相关推荐

  1. html中b标签去加粗,html中b加粗标签的详细介绍

    html作为网页最基础的语言是每一个站长必学的语言,今天我们就来了解字体文本标签 b,/b标签的用法及其语义. 字体文本标签讲解标签 字体标签定义字体的显示效果,有些标签它有独自的语义. 标签 感谢您 ...

  2. html5 a标签去下划线,css中如何去掉a标签的下划线?

    我们在HTML网页制作过程中,相信大家对css文本超链接这个概念并不陌生.我们都知道想要给某段文本或者指定元素添加一个锚点也就是超链接需要用到HTML中的a标签. 那么有的新手可能就会发现,在使用a标 ...

  3. android 推送的小图标,android - 推送通知中没有声音并且没有自定义的小图标 - 堆栈内存溢出...

    我已经使用Firebase Cloud Messaging实现了推送通知,除了几个自定义问题之外,其他所有功能都正常运行: 当我从Notification Composer工具发送测试通知时,清单中设 ...

  4. linux终端 多标签,Linux有问必答:如何在 Ubuntu 15.04 的 GNOME 终端中开启多个标签...

    问: 我以前可以在我的 Ubuntu 台式机中的 gnome-terminal 中开启多个标签.但升到 Ubuntu 15.04 后,我就无法再在 gnome-terminal 窗口中打开新标签了.要 ...

  5. mysql embed_html中object和embed标签的区别

    ♦object定义一个嵌入的对象.请使用此元素向您的 XHTML 页面添加多媒体.此元素允许您规定插入 HTML 文档中的对象的数据和参数,以及可用来显示和操作数据的代码. ♦ 标签用于包含对象,比如 ...

  6. 如何在XML中注释掉一个标签块?

    如何在XML中注释掉一个标签块? 即我如何在下面的代码中注释掉<staticText>及其中的所有内容? <detail><band height="20&qu ...

  7. JSP中 JSTL和EL标签的使用

    使用JSTL前的准备 想要使用JSTL,首先需要给工程导入JSTL的包(JSTL.jar和standard.jar). JSTL简介 JSP标准标签库(JSTL)是一个JSP标签集合,它封装了JSP应 ...

  8. php html中的判断,php怎么判断字符串中是否包含html标签?

    php判断字符串中是否包含html标签的方法:首先使用"strip_tags"函数处理字符串:然后使用if语句判断处理后的字符串"str2"和原字符串" ...

  9. dedecms二级菜单中判断子菜单标签的方法

    这篇文章将为大家详细讲解有关dedecms二级菜单中判断子菜单标签的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获. 虚拟接口是用户本地数据中心通过海外专线访问V ...

  10. HTML areamap标签及在实际开发中的应用

    HTML <area><map>标签及在实际开发中的应用 by zhangxinxu from http://www.zhangxinxu.com/wordpress/?p=6 ...

最新文章

  1. 【代码笔记】Web-CSS-CSS id和Class选择器
  2. 直播回顾|基于格雷码结合相移技术的高鲁棒性高效率动态三维面形测量
  3. Fuzz学习笔记(一)—— WinAFL环境搭建与基本使用
  4. struts2的OGNL表达式(三)
  5. 强制生成32位arm程序_ARM版本系列及家族成员梳理
  6. CSP2020洛谷P7077:函数调用
  7. C++远航之封装篇——默认构造函数、初始化列表、拷贝构造函数
  8. linux以太网连接树莓派,如何在没有Internet的情况下直接连接到树莓派
  9. python基础教程-Python基础
  10. 动态代理解决网站字符集编码
  11. HTML5之WebSocket
  12. 《软件工程(第4版?修订版)》—第2章2.7节本章对单个开发人员的意义
  13. 十个最好的免费杀毒软件
  14. PDP上下文和PDP地址
  15. 三跨难不难 还跨计算机,计算机专业考研学校
  16. 对拉格朗日乘数法的直观认识
  17. 线性方程组的矩阵形式
  18. mysql学习-Innodb行格式compact行记录解析
  19. 氢os android 7.0,氢OS 3.0正式推送!基于Android 7.0,简洁纯净
  20. 怎么监测facebook上竞争对手的广告

热门文章

  1. 哪款蓝牙耳机降噪效果好?降噪效果好的蓝牙耳机排行榜
  2. 择校秘籍|保研去 北大软微 还是 中科院计算所?
  3. c++保留有效位和小数位
  4. 大一计算机专业学期计划范文,大一新学期学习计划范文(通用5篇)
  5. win系统自带校验命令
  6. 梅隆大学计算机专业申请,卡内基梅隆大学计算机专业申请条件(附案例)
  7. 共享单车信息系统服务器部署,共享单车云服务器搭建
  8. Algorithm:矩阵中“块”的个数
  9. 抽基类与PullToRefreshListView
  10. 开发者 发展 程序物语