[教程] 谈谈网页设计中的字体应用 (4) 实战应用篇·下

Yoho, 大家好,又是我哟~

首先抱歉让大家等了这么多时间。最近实在比较繁忙啦。不过我还是会尽量抽空出来给大家讲点有的没的,欢迎大家继续关注哦。

上次我讲了在实际应用font-family时会遇到的浏览器兼容性问题。这次我 要从操作系统方面来讲如何安排字体族。另外,由于中文字体的选择范围实在太小,所以本章中设计的内容主要以西文字体为主,比较适合上一章中的“方案二”。

- 不同操作系统的常用字体

如何让你的字体在任何系统,任何电脑上都看起来一致?

原则很简单。尽可能使用所有操作系统都存在的字体。虽然听起来比较简单,但是其实还是很tricky的一件事情。为此,你首先需要了解常用的操作系统的字体。

下面我会列出一些除了windows以外的常用操作的默认字体。windows么……想来大家应该已经很熟悉了

- Mac OS X 中的常用字体

一个典型安装的 Mac OS X 10.4 会包含以下常用西文字体(某些非常用字体就不列出了):

sans-serif serif monospace
Helvetica Times Courier
Arial Times New Roman Courier New
Arial Narrow Georgia  
Arial Black    
Comic Sans MS    
Gill Sans    
Impact    
Trebuchet MS    
Verdana    
Lucida Grande    

- 典型的 Linux 字体

典型的Linux只有kernel,所以字体要自己安装

既然这样,自然无法正确预测使用Linux的用户装了啥字体。不过好在大家都会装一些常用的字体,因此不会有什么大问题。

 

- 比较各个操作系统的字体,我们会发现——

其实,windows 常用的字体其它操作系统都有,甚至很多人认为windows only 的 Arial 字体也不例外~

不少设计师都认为 Arial 是个不典雅的字体,所以希望在 Mac 上能用更经典的 Helvetica 字体来代替,于是产生了这种代码:

font-family: Arial, Helvetica, sans-serif;

但是因为Mac OS 其实也有Arial 字体,所以永远都只会显示Arial

其实这种问题,只要稍加修改就OK了啦:

font-family: Helvetica, Arial, sans-serif;

 

但是事情往往不是这么简单的。比如上面的Mac OS X字体表中,由个 Lucida Grande 字体。照理说这个字体是Mac only的,所以大家理应可以放心的这么写:

font-family: "Lucida Grande", Arial, sans-serif;

那么Mac用户可以看到Lucida Grande, 而PC用户可以看到Arial字体。多好的应用典范。

但是实际上呢,不少PC用户居然看到了乱码,而不是 Arial 字体

怎么回事呢?因为市面上有不少字体下载网站,而上面就有那个Lucida Grande下载。可惜这个广为流传的 Lucida Grande 是个rip版,而且rip的时候有缺陷,导致所有换行字符都会显示成一个乱码……

——囧大了

不要说这种事情只会在乱装英文字体的用户上发生哟。能在XP上显示微软雅黑的,不都是rip版的嘛——那个网上广为流传的版本,也存在着类似缺陷,只不过不至于严重到产生乱码而已。所以在选择字体时需要注意一下。

- 常用西文字体介绍

Tahoma 16px  Tahoma 14px  Tahoma 12px

Tahoma是我本人比较喜欢的一种非衬线字体。首先几乎所有的系统都默认安装了这个字体,所以不会存在兼容性问题,其次,这个字体也比较均衡,显示段落也不错。

 

Verdana 16px  Verdana 14px  Verdana 12px

说老实话,Verdana太宽了,不适合中英文混排。很多时候Verdana的一个字母都要比同样size的中文字符宽了。国外设计师喜欢用Verdana, 很多时候是因为Verdana 11px以下的小字效果的确十分理想,但是国内很多设计师想也不想就照搬过来,并用在12px 乃至14px的布局上,导致本来就局促的空间更显紧张,所以不推荐作为font-family 打头阵的字体。

如果要使用Verdana字体的话,就一定要考虑它和一般系统default的sans-serif字体之间的大小差距。不论和Helvetica 或者Arial 比起来,Verdana都大得多了。不过好在几乎所有的系统也都会默认安装这个字体……

 

Trebuchet MS 16px  Trebuchet MS 14px  Trebuchet MS 12px

Trebuchet MS 是个很多人都会忽视的字体。其实我个人也比较欣赏这个字体的。与其使用Verdana, 还不如用这个线条更圆润的的字体来替代。对各种操作系统也有很好的支持。

缺点是和Verdana一样,因为过宽,而不适合用在中英文混排。也要注意和default sans-serif font 宽度差距的问题。

因为考虑到有些Linux 系统可能不会安装这个字体,所以如果要用在一个font-family的开头话,可以使用Verdana 做后续字体。

 

Arial 16px  Arial 14px  Arial 12px

Windows 操作系统的默认sans-serif 字体。没啥好说的,永远都不会用到的默认字体。

 

Helvetica 16px  Helvetica 14px  Helvetica 12px

为啥同样是默认字体,Helvetica 就这么典雅呢?  哪怕就是用在font-family的开头也是能独挡一面的啦。

另外,这里有个 Helvetica 和 Arial 打架的flash游戏~ 像超级玛利一样踩 Arial 字符就可以了。顺便没有 Helvetica 字体的人可以看一下两个字体的具体区别~ 茶~

 

Georgia 16px  Georgia 14px  Georgia 12px

我最喜欢用的 serif 字体。不仅很适合做正文,也适合做标题。尤其是意大利体的 Georgia Italic 更是魅力难挡。缺点仍旧是不适宜和汉字混排,因为Georgia的衬线哪怕对于宋体来说也太重了,所以看上去硬邦邦的……

 

Times New Roman 16px  Times New Roman 14px  Times New Roman 12px

Windows 的默认serif 字体。没啥好说的,西文字体的元老了。很多字体,比如大家都熟悉的Courier New都是从Times New Roman派生出来的。

不过现在印刷业都很少用这个字体了,更多的是在用它的后代——Times Europa 和 Times Europa Office。

在具体的网页字体应用上,要注意同样字号的Times New Roman比普通字体小的多,所以一定要考虑进字体大小的变化

 

Courier New 16px  Courier New 14px  Courier New 12px

常用的等宽字体之一。其实等宽字体的选择比较小啦,所以基本上要兼容所有系统,也就只能选这个字体了。

不过还好,等宽字体通常都是在写代码的时候有用,所以只要等宽就没什么大问题。类似于 Lucida Sans Typewriter, Lucida Console, Monaco 之类的字体也都很好用。

- 综上所述,总结几套实用而简单的font-family

font-family: Tahoma, Helvetica, Arial, sans-serif;

Tahoma 系的中性字体。推荐使用在13px以上的环境。

 

font-family: Trebuchet MS, Verdana, Helvetica, Arial, sans-serif;

Verdana 系的宽扁字体。推荐在11px以下环境使用。

 

font-family: Geogia, Times New Roman, Times, serif;

衬线字体的不二之选。

 

font-family: Lucida Console, Monaco, Courier New, mono, monospace;

一系列等宽字体。写代码很好用。另外,如果觉得Lucida Console太宽的话,可以换成比较窄的Lucida Sans Typewriter。话说老赵blog上的代码块使用的就是Lucida Sans Typewriter 哟~

- 你知道吗?

  • 字体的别名

    系统中的一个字体是允许有多种别名形式存在的。比如,在windows 下,Georgia 也可以用 Georgia MS 来命名,它们其实是同一种字体。宋体的正式名称是SimSon,而“宋体”只是它的别名。

    按照规范,浏览器应该能自动识别字体的别名,并映射到正确的字体文件。比如,font-famliy: SimSon 和 font-family: "宋体" 应该具有等价的效果。可惜,似乎很多浏览器都不能正确执行前一条定义……

  • 什么时候在字体名称前面加引号

    大家来看这个字体样式定义:

    font-family: Times New Roman, 宋体, serif;

    很多人都会说,这个样式写法是错的,因为 Times New Roman 和宋体都应该用引号括起来,像下面这样:

    font-family: "Times New Roman", "宋体", serif;

    实际上呢,上面两种写法都是对的。和很多人想象中的不一样,字体名称外面的引号其实并非必须的。那么加引号和不加引号有什么区别呢?

    其实最大的不同在于对字体名称中空白字符(如空格、制表符)的解释。

    不加引号的时候,浏览器对于字体名称中空白字符的解释应该和XML中一样,即忽略字体名称左右的空白字符,并且单词中间的空白字符被解释为一个空格。比如 font-family:         Times       New  Roman                , serif; 会被解释成 font-family: Times New Roman, serif;

    加引号的时候,浏览器必须保留引号内所有的空白字符。如果写成 font-family: "Times       New Roman"; 那么浏览器不会显示 Times New Roman 字体,而是搜索一个叫做“Times       New Roman”的字体。

    至于“宋体”这样的字体名称,因为中间没有空白字符,因此完全没有必要加引号。但是考虑到并非左右的操作系统都有汉字支持,并且并非所有的程序员都会注意css文件的正确编码问题,所有保险起见,一般会加上引号。当然,解决这种问题的最好方法是使用别名。比如宋体,其实应该写成SimSon,这样哪怕浏览者的系统不支持中文,并且这个css文件被错误的编码成了GB2132也没问题,浏览器还是知道这是宋体,并且做出正确的字体搜索。可惜,不是所有浏览器都支持就是了……

 

网页设计中的字体应用这个专题就讲到这里了,希望对大家有所帮助。下次我打算讲一下在项目中如何应用样式表管理,适合稍微有些样式表基础,并且正在参与、或者有意参与大型开发项目的朋友们听哦~ 其中还可能穿插一些小文章,解释一些实际工作中大家遇到的容易误解的地方。不过最近偶会比较忙一些,所以可能会花些时间来写,请大家耐心等待啦。

那么,大家下次见了哟~

posted @ 2008-06-26 16:23 棕熊 阅读(3972) 评论(24)  编辑 收藏 网摘 所属分类: CSSVI设计

  回复  引用  查看    
#1楼2008-06-26 16:27 | 3b阿当      
占个沙发慢慢看:)
  回复  引用  查看    
#2楼2008-06-26 16:28 | 二手的程序员      
二楼也行
  回复  引用  查看    
#3楼2008-06-26 16:28 | 3b阿当      
上午还突然想到怎么很久不见到黑色背景了,汗~~
  回复  引用  查看    
#4楼2008-06-26 16:45 | 痴情客      
great ,大侠 ,不过我这有个问题:

http://scriptlover.com/" target="_new">http://scriptlover.com/

我用了georgia字体 ,英文看起来很舒服 ,可是中文就 。。。

你看下有解决的方案吗?

  回复  引用  查看    
#5楼[楼主]2008-06-26 16:51 | 棕熊      
@3b阿当
@二手的程序员
@3b阿当
抱歉让大家久等了哦=v=

@痴情客
关于这个,可以参考下我前面的文章以及回复
http://www.cnblogs.com/ruxpinsp1/archive/2008/05/11/font-in-front-end-development-3.html
目前可用的解决方法有3个:
1. 放弃英文
2. 放弃中文
3. 用<span lang="en" class="en">把英文括起来,和中文分开写样式
都是折中的办法,具体看你更注重哪部分内容了

  回复  引用  查看    
#6楼[楼主]2008-06-26 16:53 | 棕熊      
@痴情客
另外建议你中文字体使用12px 等常规size, 而不要用0.8em
这样会好很多

  回复  引用  查看    
#7楼2008-06-26 17:03 | 痴情客      
非常感谢 ,我中英文都不想放弃 ,看来只能在必须的地方写span再加样式了


另:我也觉得12px比较好,但有个问题, 在ie下:

单位设为像素的时候 ,点击浏览器的缩放字体没有用 ,不知道这个 。。。。怎么解决..

  回复  引用  查看    
#8楼2008-06-26 17:06 | Ryan Gene      
font-family: Trebuchet MS, Verdana, Helvetica, Arial, sans-serif;

这个不错,很实用的文章,谢谢~


  回复  引用  查看    
#9楼[楼主]2008-06-26 17:13 | 棕熊      
@痴情客
最简单的解决方法是提示IE6用户升级浏览器=v=
另外,真正要做字体缩放之前,先要仔细考虑,你的网站是不是已经准备好字体缩放的冲击——比如字体放大后,是不是会把某些结构撑坏,或者背景图片不能跟着stretch之类
如果准备好了,那么其实可以写个javascript 小脚本来做这件事情,酱紫。
其实解决这个问题最完美的办法是css给我们提供的media query
不过还是等所有浏览器支持这个再说吧……

  回复  引用  查看    
#10楼2008-06-26 17:27 | 痴情客      
study ,您说的这几个问题都是需要考虑的

我的缩放结构是没问题的,背景也ok

另外不知道你所说的 media query ,呵呵

  回复  引用  查看    
#11楼[楼主]2008-06-26 17:32 | 棕熊      
@痴情客
所谓的media query, 是css3中引入的一个feature
有了这个,就能很方便的判断用户浏览的一些环境变量,比如屏幕分辨率,宽度之类
具体可以看这个
http://www.w3.org/TR/css3-mediaqueries/" target="_new">http://www.w3.org/TR/css3-mediaqueries/

  回复  引用  查看    
#12楼2008-06-26 17:35 | 痴情客      
very good ,学习了。


仔细阅读阅读先

  回复  引用  查看    
#13楼2008-06-26 17:50 | 瑞克梅塔      

  回复  引用  查看    
#14楼2008-06-26 18:12 | 生鱼片      
font-family可以说这么多啊
  回复  引用  查看    
#15楼2008-06-26 21:49 | airwolf2026      
(*^__^*) 嘻嘻…….好东西
  回复  引用    
#16楼2008-06-27 02:22 | 净化工作台[未注册用户]
选股攻略实战应用。*
  回复  引用    
#17楼2008-06-29 15:25 | leeight的马甲[未注册用户]
终于有更新了
  回复  引用  查看    
#18楼2008-09-04 19:11 | 随风流月      
请教一下, Microsoft Yahei 在 XP 下发虚, 怎么让 XP 使用宋体而 Vista 使用雅黑?
  回复  引用  查看    
#19楼[楼主]2008-09-07 01:23 | 棕熊      
@随风流月
其实一台正常的XP系统,是不会带雅黑字体的,所以默认就是宋体,不必做任何特殊处理
另外,雅黑在XP下发虚是因为XP使用的字体渲染标准和vista的不一样,所以不推荐在XP下装雅黑,除非你有一台非常好的液晶显示器,而且启用了cleartype

  回复  引用  查看    
#20楼2008-10-18 15:04 | Selfocus      
我遇到过在css中,font-family:Verdana 宋体 firefox的中文显示成了隶书,狂汗-_-!
  回复  引用  查看    
#21楼[楼主]2008-10-30 11:47 | 棕熊      
@Selfocus
这个是因为你在 Verdana和宋体之间没用逗号,于是firefox认为是"Verdana 宋体" 这么一个字体,并且在你的字体库里没有找到,于是就使用它自己的默认字体(你可以在firefox的选项里设置),而你的firefox默认字体应该被设到隶属上了吧……

  回复  引用    
#22楼2009-02-13 14:33 | 挖客[未注册用户]
很好的教程文章
  回复  引用    
#23楼2009-04-28 16:23 | nmgfrank[未注册用户]
不错的文章,令我受益匪浅!
  回复  引用    
#24楼2009-07-01 10:00 | 胡[未注册用户]
为什么我还是没有明白平常的页面该设置什么字体以及顺序



发表评论

昵称: [登录] [注册]

主页:

邮箱:(仅博主可见)

评论内容:

  登录  注册

[使用Ctrl+Enter键快速提交评论]

0 1191564




相关文章:

相关链接:

版权声明

除特别声明外,本站一切资源均适用于
Creative Commons License This work by 棕熊 is licensed under a Creative Commons Attribution-Noncommercial-No Derivative Works 2.5 China Mainland License
PS: 这个blog目前暂时不能完美支持IE6