Heim  >  Artikel  >  Web-Frontend  >  css3 web字体记_html/css_WEB-ITnose

css3 web字体记_html/css_WEB-ITnose

WBOY
WBOYOriginal
2016-06-24 11:41:181233Durchsuche

css3 web字体

@font-face语法

  @font-face能够加载服务器端的字体,让客户端浏览器显示客户端没有安装的字体。

@font-face{	font-family:<YourWebFontName>;	src:<source> [<format>] [,<source> [<format>]] *;	[font-weight:<weight>];	[font-style:<style>];}

  :指定的是自定义的字体名称,最好是使用下载的默认字体文件名,它将被引用到web元素中的font-family。
  :指定的是自定义的字体存放路径,可以是相对路径也可以是绝对路径。
  :指定的是自定义的字体格式,主要用来帮助浏览器识别,其值主要有以下几种类型,如trutype,opentype,truetype-att,embedded-opentype,avg等。
  :前者用来指定字体是否为粗体,后者主要定义字体样式。除了这两个属性,类似的属性还有font-variant,font-size等。

实现@font-face

  正常使用@font-face自定义字体,需要满足以下几个关键点。

  1. 将各种格式字体上传到服务器上,以支持各种浏览器。
  2. 在@font-face中显示指定自定义字体名
    称以及应用自定义字体的字体来源。

    @font-face {	font-family:'SingleMaltaRegular';	src: url('../fonts/singlemalta-webfont.eot');	src: url('../fonts/singlemalta-webfont.eot?#iefix') format('embedded-opentype'),		 url('../fonts/singlemalta-webfont.woff') format('woff'),		 url('../fonts/singlemalta-webfont.ttf') format('truetype'),		 url('../fonts/singlemalta-webfont.svg#SingleMaltaRegular') format('svg');}

  代码块中的font-family和src都是必须的,通过font-family来自定义字体,而src是引用自定义字体的来源。
  @font-face规则中的font-family与样式中的font-family略有不同。在@font-face中的font-family只是声明了字体的名称,而没有向元素中分配这种字体。而样式中的font-family却是显示地为元素指定字体名称。
  在@font-face规则中通过font-family来自定义字体名称,这个名称可以是任意的名称,它仅用于元素样式中的font-family属性引用。
  上面代码通过@font-face声明了字体名“SingleMaltaRegular”,但并不会有任何实际效果,如果想让web字体中的文本字体是SingleMaltaRegular,需要在样式代码块中的对应元素中引用@font-face定义好的字体,如:

h2{font-family:"SingleMaltaRegular";}

  因为不同浏览器兼容性问题,对字体格式的支持也各有不同,下面来了解一下各个版本浏览器支持什么字体。

  1. TureTpe(.ttf)格式:

    .ttf字体是Windows和Mac的最常见的字体,是一种RAW格式,因此他不为网站优化,支持这种字体的浏览器有【IE9+,Firefox3.5+,Chrome4+,Safari3+,Opera10+,iOS Mobile Safari4.2+】;

  2. OpenType(.otf)格式:

.otf字体被认为是一种原始的字体格式,其内置在TureType的基础上,所以也提供了更多的功能,支持这种字体的浏览器有【Firefox3.5+,Chrome4.0+,Safari3.1+,Opera10.0+,iOS Mobile Safari4.2+】;

  1. Web Open Font Format(.woff)格式:

    .woff字体是Web字体中最佳格式,他是一个开放的TrueType/OpenType的压缩版本,同时也支持元数据包的分离,支持这种字体的浏览器有【IE9+,Firefox3.5+,Chrome6+,Safari3.6+,Opera11.1+】;

  2. Embedded Open Type(.eot)格式:

    .eot字体是IE专用字体,可以从TrueType创建此格式字体,支持这种字体的浏览器有【IE4+】;

  3. SVG(.svg)格式:

    .svg字体是基于SVG字体渲染的一种格式,支持这种字体的浏览器有【Chrome4+,Safari3.1+,Opera10.0+,iOS Mobile Safari3.2+】。

  这就意味着在@font-face中我们至少需要.woff,.eot两种格式字体,甚至还需要.svg等字体达到更多种浏览版本的支持。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn