首页 > 开发 > CSS > 正文

CSS教程:网页字体的设置和控制

2024-07-11 08:21:49
字体:
来源:转载
供稿:网友
  div css网页布局中对字体的控制是非常重要的,对于需要精确效果的页面而言。这类设置会非常有用。对于一般用户与开发者而论,使用浏览器默认字体即可,VeVb.com鲜有这方面的知识的介绍。此文分享了作者很独特的css实践经验。从此文可以看出。对页面字体的控制与设置的思考,将css的工作进行的更加深入了。

body {font-family: arial, sans-serif; }

  这是我迄今发现的最好的全局字体解决方案。当然,所谓“最好”,也只是基于我个人的评判标准。所以我还是得分析一下其他的写法有什么缺点,最后再总结这个写法的特点。

body {font-family: "宋体", sans-serif; }

   这个写法可能的缺点在于:
  1. 宋体在safari和vista的ie 7下,看起来很难看。(我稍后把截图补上)
  2. 宋体的英文字很难看。
  3. 如果在css里写中文,你得小心你html和css的编码是否一致。

body {font-family: simsun,sans-serif; }

  这样写,可以避免上面的第三个问题。但是宋体本身确实很难看。我们希望在不同平台下,都用各自默认的字体。xp是宋体,vista是微软雅黑,mac是黑体。这样的话,只能将字体的第一个设置为英文字体,这样遇到中文的时候,浏览器会自动调用默认字体(vista ie 7的一些版本里貌似默认还是宋体,这个我就无能为力了,交给用户设置的自主权吧)

body {font-family: tahoma, sans-serif; }

  这是一个不错的解决办法。tahoma其实是一个挺漂亮的字体(我同事喜欢称它“大河马”,哈哈)。但是它其实会带来一些问题:
  1. 由tahoma显示的中文,在ie 6里,下划线会紧紧的贴住中文字,很难看。
  2. ie 6下,tahoma无法正确的设定为13px。它会跟14px一样大。但是其他浏览器没有这个问题。
  3. 如果一行里同时出现中文和英文,且这一行里有元素被定义了vertical-align属性,在ie 6、7里会导致文字高低不齐,甚至下划线错位。

body {font-family: arial, ans-serif; }

  上述两个问题,arial都没有。但是arial也有缺点:
  1. 比tahoma难看。
  2. tahoma里的第三个问题也同样存在。
  不过,这个bug是有个解决办法的,就是将这一行定义zoom:1。

  所以,如果不嫌难看,定义为arial是最合适的。如果实在不喜欢,可以将全局定义为tahoma,然后再将有下划线的(如链接)文字定义为arial,至少可以缓解一下。
  最后,对于全局字体,补充一点:
  ie里,所有的表单元素都不继承body的字体属性,需要单独设置:

input, label, select, option, textarea, button, fieldset, legend {
    font-family:tahoma,sans-serif;
}
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表