zoukankan      html  css  js  c++  java
  • css3 web字体记

    css3 web字体

    @font-face语法

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

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

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

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

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

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

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

    5. SVG(.svg)格式:

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

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

  • 相关阅读:
    面试题系列--【vue的生命周期】
    面试题系列--【hash和history的区别】
    ES6系列--【事件循环 EventLoop(Promise,setTimeOut,async/await执行顺序)】
    ES6系列--【ES6数组新增方法】
    ES6系列--【ES6 新增字符串方法】
    微信小程序系列--【VXML语法、VMSS样式、条件渲染、列表渲染、模板、引用、组件、事件系统】
    微信小程序系列--【小程序注册、工程创建、全局配置、页面配置】
    微信小程序系列---【五星好评案例】
    react系列---【Hooks】
    2019.9.18-单向循环链表删除元素(+之前完整代码)
  • 原文地址:https://www.cnblogs.com/fxycm/p/4638893.html
Copyright © 2011-2022 走看看