CSS(3)CSS文本控制:字体样式与文本布局

参考资料: houdunren文本控制MDN基本文本和字体样式

用于样式文本的 CSS 属性通常可以分为两类:

  • 字体样式: 作用于字体的属性,会直接应用到文本中,比如使用哪种字体,字体的大小是怎样的,字体是粗体还是斜体,等等。
  • 文本布局风格: 作用于文本的间距以及其他布局功能的属性,比如,允许操纵行与字之间的空间,以及在内容框中,文本如何对齐。

1. 字体种类

最简单的使用方法:

p {
  font-family: Helvetica, Arial, sans-serif;
}
  • 如果字体不可用,那么就会用浏览器默认的字体代替 default font.
  • 网页安全字体:某几个字体通常可以应用到所有系统,因此可以毫无顾忌地使用。
  • 字体栈 (font stack):定义多个字体,系统会依次查找,没有用引号的是无效的。
font-family: 'Courier New', Courier, monospace;
  • 不建议使用中文字体,因为文件太大且大部分是商业字体(需要版权)。

@font-face方法

@font-face 是一个CSS@规则 ,它允许网页开发者为其网页指定在线字体。 通过这种作者自备字体的方式,@font-face 可以消除对用户电脑字体的依赖。 @font-face 不仅可以放在在CSS的最顶层, 也可以放在 @规则 的条件规则组 中。
语法

<style>
  @font-face {
    font-family: "houdunren";
    src: url("SourceHanSansSC-Light.otf") format("opentype"),
         url("SourceHanSansSC-Heavy.otf") format("opentype");
  }

  span {
    font-family: 'houdunren';
  }
</style>
字体 格式
.otf opentype
.woff woff
.ttf truetype
.eot Embedded-opentype

参考:真正了解CSS3背景下的@font face规则

Font 简写

许多字体的属性也可以通过 font 的简写方式来设置 .

p{
  font: italic normal bold normal 3em/1.5 Helvetica, Arial, sans-serif;
}

按照以下顺序来写: font-style, font-variant, font-weight, font-stretch, font-size, line-height, and font-family.

  • font-sizefont-family 是一定要指定的。
  • font-sizeline-height 属性之间必须放一个正斜杠。

2. 字体颜色、大小、样式、粗细、转化、装饰、阴影

p {
  color: red;
  font-size: 10px; // em, rem;
  font-style: normal; // italic, oblique
  font-weight
}

2.1 颜色

  • 字符串颜色:可以使用如 red, green 等字符颜色声明
  • 使用十六进制网页颜色:color:#ddffde
    如果颜色字符相同如 #dddddd 可以简写为 #ddd
  • 使用RGB颜色:例如:color:rgb(38, 149, 162);
  • 透明颜色:透明色从 0~1 间,表示透明到不透明,例:color:rgba(38, 149, 162,.2);

2.2 大小

2.2.1单位
  • px : 像素值,一个绝对单位。
  • em: 1em 等于我们设计的当前元素的父元素上设置的字体大小。常用于首行缩进。
  • rem: 效果和 em 差不多。1rem 等于 HTML 中的根元素的字体大小, (i.e. <html>) ,而不是父元素。rem 不支持 Internet Explorer 8 和以下的版本,如果你的项目需要支持较老的浏览器,你可以坚持使用empx, 或者是 polyfill 就像 REM-unit-polyfill.
2.2.2 百分数

百分数是子元素相对于父元素的大小,如父元素是20px,子元素设置为 200%即为你元素的两倍大小。

2.3 字体样式(倾斜)

  • font-style: 用来打开和关闭文本 italic (斜体)。 可能的值如下 (你很少会用到这个属性,除非你因为一些理由想将斜体文字关闭斜体状态):
    • normal: 将文本设置为普通字体 (将存在的斜体关闭)
    • italic: 如果当前字体的斜体版本可用,那么文本设置为斜体版本;如果不可用,那么会利用 oblique 状态来模拟 italics。
    • oblique: 将文本设置为斜体字体的模拟版本,也就是将普通文本倾斜的样式应用到文本中。

2.4 字体粗细

  • font-weight: 设置文字的粗体大小。这里有很多值可选 (比如 -light, -normal, -bold, -extrabold, -black, 等等), 不过事实上你很少会用到 normalbold以外的值:
    • normal, bold: 普通或者加粗的字体粗细
    • lighter, bolder: 将当前元素的粗体设置为比其父元素粗体更细或更粗一步。100900: 数值粗体值,如果需要,可提供比上述关键字更精细的粒度控制。
    • 400对应 normal, 700 对应 bold

2.5 文本转化

  • text-transform: 允许你设置要转换的字体。值包括:
    • none: 防止任何转型。
    • uppercase: 将所有文本转为大写。
    • lowercase: 将所有文本转为小写。
    • capitalize: 转换所有单词让其首字母大写。
    • full-width: 将所有字形转换成全角,即固定宽度的正方形,类似于等宽字体,允许拉丁字符和亚洲语言字形(如中文,日文,韩文)对齐。

2.6 文本装饰

  • text-decoration: 设置/取消字体上的文本装饰 (你将主要使用此方法在设置链接时取消设置链接上的默认下划线。) 可用值为:
    • none: 取消已经存在的任何文本装饰。
    • underline: 文本下划线
    • overline: 文本上划线
    • line-through: 穿过文本的线 strikethrough over the text.

text-decoration 可以一次接受多个值,如果你想要同时添加多个装饰值, 比如 text-decoration: underline overline.。同时注意 text-decoration 是一个缩写形式,它由 text-decoration-line, text-decoration-styletext-decoration-color 构成。你可以使用这些属性值的组合来创建有趣的效果,比如 text-decoration: line-through red wavy.

2.7 阴影

参数顺序为:阴影颜色,水平偏移,垂直偏移,阴影模糊度。

<style>
  h2 {
    text-shadow: rgba(13, 6, 89, 0.8) 3px 3px 5px;
  }
</style>

3. 文本布局

3.1 文本对齐

text-align 属性用来控制文本如何和它所在的内容盒子对齐。可用值如下,并且在与常规文字处理器应用程序中的工作方式几乎相同:

  • left: 左对齐文本。
  • right: 右对齐文本。
  • center: 居中文字
  • justify: 使文本展开,改变单词之间的差距,使所有文本行的宽度相同。你需要仔细使用,它可以看起来很可怕。特别是当应用于其中有很多长单词的段落时。如果你要使用这个,你也应该考虑一起使用别的东西,比如 hyphens,打破一些更长的词语。

3.2 行高

line-height 属性设置文本每行之间的高,可以接受大多数单位 length and size units,不过也可以设置一个无单位的值,作为乘数,通常这种是比较好的做法。无单位的值乘以 font-size 来获得 line-height

3.3 字母和单词间距

p {
  letter-spacing: 2px;
  word-spacing: 4px;
}

3.4 其他一些值得看一下的属性

以上属性让你了解如何开始在网页上设置文本, 但是你可以使用更多的属性。我们只是想介绍最重要的。一旦你习惯使用上面的内容,你还应该探索以下几点:

Font 样式:

  • font-variant: 在小型大写字母和普通文本选项之间切换。
  • font-kerning: 开启或关闭字体间距选项。
  • font-feature-settings: 开启或关闭不同的 OpenType 字体特性。
  • font-variant-alternates: 控制给定的自定义字体的替代字形的使用。
  • font-variant-caps: 控制大写字母替代字形的使用。
  • font-variant-east-asian: 控制东亚文字替代字形的使用, 像日语和汉语。
  • font-variant-ligatures: 控制文本中使用的连写和上下文形式。
  • font-variant-numeric: 控制数字,分式和序标的替代字形的使用。
  • font-variant-position: 控制位于上标或下标处,字号更小的替代字形的使用。
  • font-size-adjust: 独立于字体的实际大小尺寸,调整其可视大小尺寸。
  • font-stretch: 在给定字体的可选拉伸版本中切换。
  • text-underline-position: 指定下划线的排版位置,通过使用 text-decoration-line 属性的underline 值。
  • text-rendering: 尝试执行一些文本渲染优化。

文本布局样式:

  • text-indent: 指定文本内容的第一行前面应该留出多少的水平空间。
  • text-overflow: 定义如何向用户表示存在被隐藏的溢出内容。
  • white-space: 定义如何处理元素内部的空白和换行。
  • word-break: 指定是否能在单词内部换行。
  • direction: 定义文本的方向 (这取决于语言,并且通常最好让HTML来处理这部分,因为它是和文本内容相关联的。)
  • hyphens: 为支持的语言开启或关闭连字符。
  • line-break: 对东亚语言采用更强或更弱的换行规则。
  • text-align-last: 定义一个块或行的最后一行,恰好位于一个强制换行前时,如何对齐。
  • text-orientation: 定义行内文本的方向。
  • word-wrap: 指定浏览器是否可以在单词内换行以避免超出范围。
  • writing-mode: 定义文本行布局为水平还是垂直,以及后继文本流的方向。

4. 不换行的应用

使用 white-space 控制文本空白显示。

  • pre 保留文本中的所有空白,类似使用 pre 标签
  • nowrap 禁止文本换行
  • pre-wrap 保留空白,保留换行符
  • pre-line 空白合并,保留换行符
    溢出文本容器后换行处理,溢出添加 ...,需要将overflow 设置在 text-overflow 前面。
h2 {
  width: 100px;
  border: solid 1px #ddd;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,928评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,748评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,282评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,065评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,101评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,855评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,521评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,414评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,931评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,053评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,191评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,873评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,529评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,074评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,188评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,491评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,173评论 2 357