如何使用CSS3 @font-face 实现个性化字体。

如何使用CSS3 @font-face 实现个性化字体。

 

在网页中,我们可以使用CSS的font-family属性来定义字体。但是,定义的字体能否在用户的电脑上正确显示,取决于用户的电脑上是否安装了该字体。我们经常看到国外的一些个人网站使用了非常漂亮的字体,而这些字体通常用户的电脑上并没有安装,所以不可能使用font-family属性。今天我们将介绍使用@font-face实现个性化字体。

 

CSS3 @font-face

  说@font-face是CSS3的新特性并不准确,因为CSS2就已经支持了这一特性,并且Internet Explorer早在第5版的时候就已经支持它了,不过IE实现方式是通过自有的eot(Embeded Open Type)字体格式,其它浏览器都不支持这个格式。@font-face支持如下属性:

  font-family:设置文本的字体名称。

  font-style:设置文本样式。

  font-variant:设置文本是否大小写。

  font-weight:设置文本的粗细。

  font-stretch:设置文本是否横向的拉伸变形。

  font-size:设置文本字体大小。

  src:设置自定义字体的相对路径或者路径。

  @font-face浏览器兼容性如下:

如何使用CSS3 @font-face 实现个性化字体。4+如何使用CSS3 @font-face 实现个性化字体。3.5+如何使用CSS3 @font-face 实现个性化字体。4+如何使用CSS3 @font-face 实现个性化字体。3.1+如何使用CSS3 @font-face 实现个性化字体。10+

一个简单例子

  先声明一个名为ChantelliAntiquaRegular的字体,有一种老的写法是这样的:

?

1 2 3 4 5 6 7@font-face {     font-family: "ChantelliAntiquaRegular";     src: url("Chantelli_Antiqua-webfont.eot");     src: local(""), url("Chantelli_Antiqua-webfont.woff") format("woff"), url("Chantelli_Antiqua-webfont.ttf") format("truetype"), url("Chantelli_Antiqua-webfont.svg#webfontZjhIjbDc") format("svg");     font-weight: normal;     font-style: normal; }

  个src是兼容IE,第二个src是兼容其它浏览器。local(“”)是一种hack写法,避免从客户端加载字体,这种写法在Android系统中有BUG,感兴趣的同学可见《Best Practice For @Font-Face CSS Takes A Turn》,改进方案是声明两个@font-face,如下:

?

1 2 3 4 5 6 7 8 9 10 11@font-face {     font-family: "ChantelliAntiquaRegular";     src: url("Chantelli_Antiqua-webfont.eot"); }  @font-face {     font-family: "ChantelliAntiquaRegular";     src: url(//:) format("no404"), url("Chantelli_Antiqua-webfont.woff") format("woff"), url("Chantelli_Antiqua-webfont.ttf") format("truetype"), url("Chantelli_Antiqua-webfont.svg#webfontMFqI76bT") format("svg");     font-weight: normal;     font-style: normal; }

  我们首先声明一个引用eot字体文件的@font-face,以确保它在IE中能正常工作,第二个@font-face引用了多个字体格式是为了兼容其它浏览器,它们将按顺序查找,直到找到支持的格式,这意味着同一个字体需要有多个格式。url(//:) format(“no404”)是一种Bulletproof写法,感兴趣的同学可见《New @Font-Face Syntax: Simpler, Easier》一文。

  其它的HTML和CSS代码如下:

?

1 2 3 4 5.font-face-display {     font: 66px ChantelliAntiquaRegular, Helvetica, sans-serif; }  <divclass="font-face-display">Take me to your heartdiv>

  最重效果如下:

  如何使用CSS3 @font-face 实现个性化字体。

免费字体网站Font Squirrel

  Font Squirrel是一个非常优秀的免费字体资源网站,收集了很多高品质字体供网页设计者免费下载,还有个字体格式生成工具@font-face generator,上传一个字体文件,可以生成多种字体格式及CSS代码,非常有用。如果你需要一些优秀的免费英文字体,这是个好去处。

  如何使用CSS3 @font-face 实现个性化字体。

  想要丰富多彩的页面就需要有更多的字体样式,人们想出了很多字体替代方案,除了@font-face方案外还有sIFR、Cufon、Typeface.js等,还有.webfont,简单说,.webfont 就是在字体中嵌入了访问许可表,浏览器可以读出这些许可信息,并决定是否应该下载和渲染这些字体。另外还有Typekit也是一种值得关注的方案,将字体放在第三方服务器上供调用。这些方案的优缺点,将会在以后做详细的介绍。

 

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/114961.html<

(0)
运维的头像运维
上一篇2025-02-17 23:40
下一篇 2025-02-17 23:41

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注