CSS3属性详解:Web字体

20,153次阅读
没有评论

共计 5178 个字符,预计需要花费 13 分钟才能阅读完成。

前言

开发人员可以为自已的网页指定特殊的字体(将指定字体提前下载到站点中),无需考虑用户电脑上是否安装了此特殊字体。从此,把特殊字体处理成图片的方式便成为了过去。

支持程度比较好,甚至 IE 低版本的浏览器也能支持。

字体的常见格式

不同浏览器所支持的字体格式是不一样的,我们有必要了解一下字体格式的知识。

TureTpe 格式:(.ttf)

.ttf 字体是 Windows 和 Mac 的最常见的字体,是一种 RAW 格式。

支持这种字体的浏览器有 IE9+、Firefox3.5+、Chrome4+、Safari3+、Opera10+、iOS Mobile、Safari4.2+。

OpenType 格式:(.otf)

.otf 字体被认为是一种原始的字体格式,其内置在 TureType 的基础上。

支持这种字体的浏览器有 Firefox3.5+、Chrome4.0+、Safari3.1+、Opera10.0+、iOS Mobile、Safari4.2+。

Web Open Font Format 格式:(.woff)

woff 字体是 Web 字体中最佳格式,他是一个开放的 TrueType/OpenType 的压缩版本,同时也支持元数据包的分离。

支持这种字体的浏览器有 IE9+、Firefox3.5+、Chrome6+、Safari3.6+、Opera11.1+。

Embedded Open Type 格式:(.eot)

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

SVG 格式:(.svg)

.svg 字体是基于 SVG 字体渲染的一种格式。

支持这种字体的浏览器有 Chrome4+、Safari3.1+、Opera10.0+、iOS Mobile Safari3.2+。

总结:

了解了上面的知识后,我们就需要为不同的浏览器准备不同格式的字体。通常我们会通过字体生成工具帮我们生成各种格式的字体,因此无需过于在意字体格式之间的区别。

下载字体的网站推荐:

WebFont 的使用步骤

打开网站http://iconfont.cn/webfont#!/webfont/index,如下:

CSS3 属性详解:Web 字体

上图中,比如我想要「思源黑体 - 粗」这个字体,那我就点击红框中的「本地下载」。

下载完成后是一个压缩包,压缩包链接:http://download.csdn.net/download/smyhvae/10253561

解压后如下:

CSS3 属性详解:Web 字体

上图中,我们把箭头处的 html 文件打开,里面告诉了我们 webfont 的 使用步骤

CSS3 属性详解:Web 字体

(1)第一步:使用 font-face 声明字体

@font-face {font-family: 'webfont';
    src: url('webfont.eot'); /* IE9*/
    src: url('webfont.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
    url('webfont.woff') format('woff'), /* chrome、firefox */
    url('webfont.ttf') format('truetype'), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/
    url('webfont.svg#webfont') format('svg'); /* iOS 4.1- */
}

(2)第二步:定义使用 webfont 的样式

.web-font{
    font-family:"webfont" !important;
    font-size:16px;font-style:normal;
    -webkit-font-smoothing: antialiased;
    -webkit-text-stroke-width: 0.2px;
    -moz-osx-font-smoothing: grayscale;}

(3)第三步:为文字加上对应的样式

<i class="web-font"> 这一分钟,你和我在一起,因为你,我会记得那一分钟。从现在开始,我们就是一分钟的朋友。这是事实,你改变不了,因为已经完成了。</i>

举例:

我们按照上图中的步骤来,引入这个字体。完整版代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>

        p{font-size:30px;}

        /*  如果要在网页中使用 web 字体(用户电脑上没有这种字体)*/
        /* 第一步:声明字体 */
        /* 告诉浏览器 去哪找这个字体 */
        @font-face {font-family: 'my-web-font';
            src: url('font/webfont.eot'); /* IE9*/
            src: url('font/webfont.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
            url('font/webfont.woff') format('woff'), /* chrome、firefox */
            url('font/webfont.ttf') format('truetype'), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/
            url('font/webfont.svg#webfont') format('svg'); /* iOS 4.1- */
        }
        /* 第二步:定义一个类名,谁加这类名,就会使用 webfont 字体 */
        .webfont{font-family: 'my-web-font';}
    </style>
</head>
<body>
    <!-- 第三步:引用 webfont 字体 -->
    <p class="webfont"> 生命壹号,永不止步 </p>
</body>
</html>

代码解释:

(1)my-web-font这个名字是随便起的,只要保证第一步和第二步中的名字一样就行。

(2)因为我把字体文件单独放在了 font 文件夹中,所以在 src 中引用字体资源时,写的路径是 font/...

工程文件:2018-02-20-WebFont 举例.zip

字体图标(阿里的 iconfont 网站举例)

我们其实可以把图片制作成字体。常见的做法是:把网页中一些小的图标,借助工具生成一个字体包,然后就可以像使用文字一样使用图标了。这样做的优点是:

  • 将所有图标打包成字体库,减少请求;

  • 具有矢量性,可保证清晰度;

  • 使用灵活,便于维护。

也就是说,我们可以把这些图标当作字体来看待,凡是字体拥有的属性(字体大小、颜色等),均适用于图标。

使用步骤如下:(和上一段的使用步骤是一样的)

打开网站http://iconfont.cn/,找到想要的图标,加入购物车。然后下载下来:

CSS3 属性详解:Web 字体

压缩包下载之后,解压,打开里面的 demo.html,里面告诉了我们怎样引用这些图标。

CSS3 属性详解:Web 字体

举例 1 :(图标字体引用)

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        /* 申明字体 */
        @font-face {font-family: 'iconfont';
            src: url('font/iconfont.eot'); /* IE9*/
            src: url('font/iconfont.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
            url('font/iconfont.woff') format('woff'), /* chrome、firefox */
            url('font/iconfont.ttf') format('truetype'), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/
            url('font/iconfont.svg#iconfont') format('svg'); /* iOS 4.1- */
        }

        .iconfont{font-family: iconfont;}

        p{
            width: 200px;
            border: 1px solid #000;
            line-height: 60px;
            font-size:30px;
            margin:100px auto;
            text-align: center;
        }

        p span{color:red;}
    </style>
</head>
<body>
    <!--【重要】编码代表图标 -->
    <p><span class="iconfont">&#xe628;</span> 扫码付款 </p>
</body>
</html>

效果如下:

CSS3 属性详解:Web 字体

举例 2 :(伪元素的方式使用图标字体)

如果想要在文字的前面加图标字体,我们更习惯采用 伪元素 的方式进行添加。

代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        /* 申明字体 */
        @font-face {font-family: 'iconfont';
            src: url('font/iconfont.eot'); /* IE9*/
            src: url('font/iconfont.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
            url('font/iconfont.woff') format('woff'), /* chrome、firefox */
            url('font/iconfont.ttf') format('truetype'), /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/
            url('font/iconfont.svg#iconfont') format('svg'); /* iOS 4.1- */
        }



        p{
            width: 200px;
            border: 1px solid #000;
            line-height: 60px;
            font-size:30px;
            margin:100px auto;
            text-align: center;
            position: relative;
        }

        .icon::before{
            /*&#xe628;*/
            content:"e628";
            /*position: absolute;*/
            /*left:10px;*/
            /*top:0px;*/
            font-family: iconfont;
            color:red;
        }

        span{position: relative;}


    </style>
</head>
<body>
    <p class="icon"> 扫码付款 </p>
    <span class="icon" > 我是 span</span>
    <div class="icon">divvvvvvvvvvv</div>
</body>
</html>

效果如下:

CSS3 属性详解:Web 字体

~ 工程文件~:

  • 2018-02-20- 图标字体 demo.zip

  • 下载链接暂无。

其他相相关网站介绍

定制自已的字体图标库:

SVG 素材:

360 浏览器网站案例

暂略。

这里涉及到:jQuery fullPage 全屏滚动插件。

使用 Bootstrap 网站的图标字体

打开如下网站:http://www.bootcss.com/p/font-awesome/

CSS3 属性详解:Web 字体

如上图所示,下载字体后,进行解压:

CSS3 属性详解:Web 字体

使用步骤如下:

(1)如图只是想要字体的话,可以把 cssfont这两个文件夹拷贝到项目里。

(2)在 html 文档中的 标签里,引入 font-awesome.min.css 文件:

    <link rel="stylesheet" href="css/font-awesome.min.css">

(3)想在哪个标签里用这个图标,直接在这个标签里加 className 就行(className 都在 网站 上列出来了)。

完整版代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="css/font-awesome.min.css">
    <style>

    </style>
</head>
<body>
    <span class="icon-play"> 播放 </span>
</body>
</html>

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于2024-09-10发表,共计5178字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)