您现在的位置是:网站首页> 编程资料编程资料
CSS first-letter实现首字下沉_CSS教程_CSS_网页制作_
2023-10-07
295人已围观
简介 关于利用first-letter实现首字下沉的一些看法
发现了问题就需要解决问题,因此我就拿这个首字下沉的时候为什么要清除浮动而做了一系列的测试,结果让我感觉有点崩溃,原来我在那章节中说明的内容太少了,在这里赶紧做个补充,希望读者朋友们能看到这篇文章后不会再对那个清除浮动而产生迷惑。
首先来看一下我在书中仅有的一段对首字下沉进行说明的代码。
p:first-letter { float:left; /* 设置段落p标签的首字为浮动,让其占据多行的空间 */ font-weight:bold; /* 加粗段落p标签的首字 */ font-size:2em; /* 设置段落p标签的首字为其他字体的2倍 */ } p {clear:both;} /* 清除首字的浮动,避免影响p标签的高度与其相叠加 */【端午节由来】
关于端午节的来历,归纳起来,大致有以下诸说:
迎涛神,此说出自东汉《曹娥碑》。曹娥是东汉上虞人,父亲溺于江中,数日不见尸体,当时孝女曹娥年仅十四岁,昼夜沿江号哭。过了十七天,在五月五日也投江,五日后抱出父尸。
春秋时吴国忠臣伍子胥含冤而死之后,化为涛神,世人哀而祭之,故有端午节。
在书中所提到的注释里,仅对p标签清除浮动做了一个简单的说明,内容如下:
p {clear:both;} /* 清除首字的浮动,避免影响p标签的高度与其相叠加 */
就是因为这么一句话,让小土豆这位读者产生了猜想,为什么要清除浮动。在部分读者眼中或许已经比较清楚明白为什么要清除浮动,因为:first-letter伪对象有一个浮动的属性。后来我想想,为什么这个有浮动属性就要清除浮动,这个问题似乎需要说明一下。
问题的出现,就需要去解决。因此我就从没清除浮动到采用不同方式的清除浮动对这段代码进行了简单分析。
未对段落首字设置浮动时
未设置浮动时的首字下沉
p:first-letter {font-weight:bold;font-size:2em;}
这时我们仅仅只是对段落中的第一个字符设置了加粗和2倍大小的文本,那么在示例图中可以看到的效果就是文字放大了而已,并未首字进行下沉的处理。
显然这不是我们所想要的效果,那么这个时候我们要做的就是对首字设置浮动,使其脱离正常的文档流

设置浮动未增加清除浮动
p:first-letter {float:left;font-weight:bold;font-size:2em;}
增加了浮动之后,我们可以看到FF/IE7/IE6中已经得到了我们所想要的效果,但是opera/safari中却出现问题了,在文本内容少的时候,第二个p标签中的文字因为浮动而跑上去了,而只有当文本出现两行的时候才会将下一个p标签的内容移开。
由此可见,清除浮动的必要性还是有的。那么我们就增加一个清除浮动的属性给p标签看看效果。

设置浮动后并增加清除浮动属性
p:first-letter {float:left;font-weight:bold;font-size:2em;}p {clear:both;}
p标签有了清除浮动的属性后,这个时候opera/safari也不再发神经式的把下一个p标签给拉上来了,不过仔细看看似乎间距存在着问题,难道还有其他因素导致了每个段落之间的间距消失了。
看来还是有些问题存在,是不是clear这个清除浮动的方式不对呢。难道是clear清除的仅仅只是浮动的属性而并没有让上一个p标签的高度自适应?带着疑惑,增加点背景色的代码给p标签看看是不是真的这样。
p:first-letter {float:left;font-weight:bold;font-size:2em;background-color:#000000;color:#FFFFFF;} p {clear:both;background-color:#FF0000;}

利用背景色检查清除浮动后的效果
果然,p标签的高度没有下来,仅仅只是清除了浮动的属性而已,清除浮动那么多的方式(具体可以参考《CSS那些事儿》中关于清除浮动的章节),这个clear不好使,那就换一个方式清除浮动。
p:first-letter {float:left;font-weight:bold;font-size:2em;background-color:#000000;color:#FFFFFF;} p {overflow:hidden;background-color:#FF0000;}

overflow方式清除浮动
浏览器的世界就是那么神奇,一个方法不行,换一个方法就会看到世界的另一面。这个时候我们可以看到背景色扩充到了整个p标签,并且每个段落之间也存在了间距了,看来问题是解决了。
在这里需要说的一点就是,overflow清除浮动的方式彪叔——梁
相关内容
- 网页变灰配合全国哀悼日的css代码 20100421_CSS教程_CSS_网页制作_
- 成语大挑战 黄色钱袋上面画着一只抢和一个军帽 答案是什么成语_手机游戏_游戏攻略_
- 天天酷跑游戏秘籍 超级模式奖励内容和开启方法分享_手机游戏_游戏攻略_
- 实况足球2014实用秘籍 防拉扯抢头球方法分享_手机游戏_游戏攻略_
- 天天酷跑宠物坐骑无限购买方法分享 无危害刷金币方法详解_手机游戏_游戏攻略_
- 百万亚瑟王加点攻略具体案例分析_手机游戏_游戏攻略_
- 百万亚瑟王日服攻略全面解析_手机游戏_游戏攻略_
- 猎鹿人2014 动物心脏打法 图文攻略_手机游戏_游戏攻略_
- 百万亚瑟王收集攻略 收集卡牌要点解析_手机游戏_游戏攻略_
- 安卓植物大战僵尸2存档位置在什么地方_手机游戏_游戏攻略_