style="text-indent:2em;">大家好,今天小编来为大家解答写字整体好看的技巧这个问题,字体比划排版怎么弄好看很多人还不知道,现在让我们一起来看看吧!
本文目录
怎样在网页中做出精彩的文字排版
字体排版绝不仅仅是使用字体那么简单,它包括了关于文字”看上去会是怎么样?”的所有事情——例如文字的大小,行高,颜色甚至文字间留白这样的细枝末节的小事。一个好的文字排版会为你所写的内容定下情感基调,并且可以帮助读者更好的理解其内容和语境。
为了让你使用起来更像是在看一本参考书而不是说明书,本文将会非常精简清晰,如果你想进一步的了解更多细节,可以点击查看在每一章中的”扩展阅读”去深入了解。
这本手册将会在GitHub上开源,并且会持续更新一些最佳实践的范例,希望你们喜欢!
字体排版设计视觉层次
视觉层次是一种理念,它意在传达页面中的元素应该依照其重要性进行组织排版,以便读者可以很容易的通览整个页面,找到相关的内容。一个好的视觉层次可以引导读者在阅读时候的视觉流向。视觉层次被广泛运用于文字排版中,它构成了文字排版设计的理论基石。
请看下图的”爱丽丝梦游仙境”的字体排版设计,它展现了一个清晰的视觉层次:
点击这里查看网页上的实际效果
视觉层次可以被分成以下4个部分:
字体大小&字体重量:设置字体大小和字体重量是两种构建视觉层次的最简单的方式。他们可以很容易地告诉读者什么地方是最重要的,引导读者的目光落到这里的内容上来。只是简单地为文字加上这两种样式,文章的重点便一目了然了。
定位:元素定位是另外的一种构建视觉层次的方式,就像上图中,文章的标题和作者信息通过置顶和居中表明了它们的重要性。
字体:通过使用有对比度的字体可以提高不同元素之间的辨识度,从而构建视觉层次
颜色:为重要的文字设置不同的颜色也是一种非常简单的构建视觉层次的方式。然而使用这种方式的时候一定要小心,因为颜色的滥用可能会造成重点部分辨识度的降低。
扩展阅读:
VisualHierarchy:HowWellDoesYourDesignCommunicate?
CreatingExcitingAndUnusualVisualHierarchies
字体排版中的格式塔原则
格式塔原则,或格式塔法则,是一种构建感性认知的规律。当我们观察这个世界的时候,我们通常会意识到,一个复杂的场景是由多个在某些背景之上的物体构成的,而这些物体则是由更小的一些物体构成的,依此循环下去。
在字体排版中我们需要理解的两个很重要的格式塔原则就是”距离原则”和”相似原则”。.
距离原则
为了更好地掌握元素定位的方法,了解距离原则是很重要的。距离原则表明,人们会将靠得近的物体视为有关联的物体,反之,隔得比较远的物体将会被看成属于不同类别。
点击此处查看原图
在字体排版设计中,”距离”指的是通过设置行高、内间距和外间距所制造出来的留白空间。在两段不同的段落之间应该留有明显的并且易于区分的留白间隔,请看下面的例子:
注意啦,你觉得应该把内容相关的部分都挤到一个很小的空间中去吗?当然不是这样,自由随意的留白也是很重要的。距离原则告诉我们,只需要为那些没有关系的段落之间额外的加上一些易于区分的留白就可以了
相似原则
格式塔的相似原则告诉大家,看起来很像的东西会被认为是一类的东西。举个例子,如果所有可点击的文字被设置为天蓝色,那么读者就会认为文章中所有天蓝色的文字内容都是可以点击的。
在字体排版中,相似原则就意味着,拥有同样功能的元素应该在样式上保持一致。如果两组元素的功能相似的话,那么它们也应该看起来很像才对。例如,两篇同为博客帖子的文章应该看起来很像。而相反的,两个功能不相同的元素也应该看起来不像。
扩展阅读:
GestaltTheoryinTypography&DesignPrinciples
Proximity,UniformConnectedness&GoodContinuation
字体选择字体
选择字体是一个具有创造性和情感的过程。不同的字体可以传达不同的情感,你可以尽情挑选一个合适的字体让你的文字感情变得丰沛起来。
首先为你的文字的正文挑选一个合适的字体,当你需要搭配不同字体的时候,记得要保持正文字体的不变,然后试着依据这个字体选择和它相搭配的其他字体。
使用一些例如TypeTester和TypeCast这一类的工具会让你进行字体选择的时候轻松一些。
从他人处获得灵感!FontsInUse提供了大量的优秀的字体搭配范例。
有些字体本来就是为用作大标题而设计的,而有些字体天生就只适合那些小屏幕,你要依照每个字体的”天性”去使用它们。你可以在WebType上面找到对于不同字体而言合适的尺寸。此外TypeKit也标明了其上的字体是适合标题或者是正文。
为了达到最大程度上的兼容,我们建议使用上面列出的格式。或者,只使用woff2和woff也会支持大部分的现代浏览器。
你需要为每个列出来的格式提供一个相应的字体文件。推荐使用Transfonter或者FontSquirrel’sWebFontGenerator,这样你就可以在只有一个字体文件的情况下,将其转换成不同的文件格式。
尽可能的压缩你的字体文件。点击这里查看更多信息。
将多个同源字体文件(细体、常规、半粗体、粗体等等)合并成一个font-family,尽量不要为每个字体都起一个新的font-family的名字。
或者,你也可以通过线上字体资源服务,如GoogleFonts或者Typekit引入你想要的字体。
扩展阅读:
FurtherHardeningOfTheBulletproofSyntax
FontSquirrel:HowToUseTheGenerator
加载字体
在你引入的字体被渲染出来之前,他们需要先进行加载。下面是三种在加载的时候可能会发生的事情:
引入的字体没有被识别出来,字体应用了备用字体。
引入的字体虽然被识别出来但是没有加载,他需要在下载完成之后才会被应用。
引入的字体被成功识别并迅速应用。
场景1只发生在你尝试使用一个不存在的字体,或者声明时候的src指向了一个坏链,这种情况可以并且应该彻底避免。接着我们跳到场景3,这种情况通常在字体被正确的缓存的时候发生,也是我们喜闻乐见的。场景2中包含着字体加载的过程,字体加载通常是难以避免的(至少是在第一次请求的时候),下面是几种处理方式:
1.文档样式闪烁方案(FOUT)
FOUT是指网页会在切换到合适的网页字体之前,使用默认或者备选字体显示文字。这种情况的出现是因为只有当HTML和CSS都被下载完成之后,字体请求才会发出。这就意味着,在HTML被显示出来而字体文件没有被完全下载下来中间存在着一段”空档”时间。FOUT算是对大部分的网页而言的最佳选择,主要是其他的选择也许更糟。如果使用得到的话,FOUT很难被用户察觉出来。
2.不可见文本闪烁方案(FOIT)
很多年前,一些现代浏览器开始使用一种新的技术来处理字体加载的问题—FOIT.FOIT是指当浏览器检测到字体正在加载的时候,隐藏应用这段字体的文字,直到字体完全下载完才将其显示出来。然而我们应该避免这种做法虽然这样做从理论上看起来还不错,但是这会带给那些网络速度比较差的用户十分糟糕的体验。有可能会在最初的FOIT后出现FOUT,最坏的情况可能会是这段文字将永远看不到了。
3.白屏方案
即在字体加载完成之前,整个网页都处于不可见的状态,或者也可以采用显示一个进度条.我们只推荐当FOUT严重影响用户体验的时候使用这种方法。我们通常在一个网页需要大面积显示一个特定的字体的时候使用该方法,否则,FOUT总会我们的第一选择,因为”内容至上”。白屏方案与FOIT很相似,但对于你来说,你拥有控制在什么时候给用户展示你的内容的自由,这种感觉会似乎更棒一些,不是吗?而且在FOIT方案中,不可见的文本有时候会给读者带来困惑,而彻底的白屏(或者一个进度条)会让人很自然的觉得是一个正在加载的信号。
不管你是打算使用FOUT方案或者白屏方案,我们都推荐您使用WebFontLoader这个JavaScript库.WebFontLoader可以让你对@font-face加以控制,而且你也为字体加载的体验添加控制事件。
注意:有一个W3C字体加载API也会实现同样的功能,但是它现在的支持不是很好_
异步地使用WebFontLoader很重要,只有这样做才不会延误页面其他部位的渲染。
写样式的时候,让你的备用字体尽可能近的靠近你的实际字体,这样才能最大程度的减少FOUT造成的影响.点击这里你将会看到一系列的备选字体.使用这个工具你将很容易的看到备选字体和你引入的字体的对比效果.
白屏方案
在这个例子里面,备选字体不需要和你引入的字体看起来很像,因为我们不会用到FOUT.依照你自己的喜好去选择备选字体吧。
如果你想要用一个进度条取代白屏,你可以使用Pace。这种方法在用户体验上效果会更好一些,特别是当字体文件很大的时候。
扩展阅读:
TypeStudy:ChoosingFallbackFonts
FOUT,FOIT,FOFT
WebFontOptimization
OpenType的特性
OpenType的特性可以被视为文字进行字体排版时的可选项,它们被用来加强文字的表现和易读性。
p{font-kerning:normal;font-variant-ligatures:common-ligaturescontextual;-moz-font-feature-settings:"kern","liga","clig","calt";-ms-font-feature-settings:"kern","liga","clig","alt";-webkit-font-feature-settings:"kern","liga","clig","calt";font-feature-settings:"kern","liga","clig","calt";}
OpenType特性被放置于字体之中,这就意味着对于不同的字体,会有不同的特性,在使用这些特性之前,我们需要看一看我们的字体是否支持这些特性。
使用font-feature-settings来激活OpenType特性.由于目前对于这个属性的支持不好,我们需要在属性之前加上前缀。
Kerningkern,ligaturesliga,contextualligaturesclig,和contextualalternativescalt这四种适用于所有字体中######(译者注:font-feature-settings这种属性仅支持拉丁文语系的字体使用,并不支持中文哦!)
WebStyleGuide相对大小
尽可能的使用相对大小。
html{font-size:100%}p{font-size:1em}@media(min-width:64em){html{font-size:112.5%;}}
font-size:100%与浏览器的字体大小设定保持一致而不是去覆写它,根据大多数的浏览器的默认设置,这里也可以用1em代替表示16px.
通过改变html的font-size会影响到所有单位为em和rem的元素.如果是对于响应式设计的网页,这样做还是比较实用的。
用户的选择也很重要,所有不要偏离font-size:100%和1em太远.
对于font-size建议使用rem和em.
对于一些元素定位如margin,padding等等,建议使用rem,em,或者%。
对于媒体查询中尺寸建议使用em.
对于一些大的标题字或者配有图片的字,可以使用FitText来实现标题的缩放。尽量避免使用vw和vh因为现在的支持还不是很好,难于精确的配置,并且对于一些浏览器的字体和缩放设置并不适配。
扩展阅读:
TypeStudy:SizingTheLegibleLetter
5UsefulCSSTricksforResponsiveDesign
REMvsEM–TheGreatDebate
PX,EMorREMMediaQueries?
容器
容器,或者称为包装,指的是用来包裹一个或者多个元素的HTML元素。它将元素分组,从而更好进行语义化、修饰以及布局。
html{box-sizing:border-box;}*,*:before,*:after{box-sizing:inherit;}.container{max-width:67rem;padding-left:1.5rem;padding-right:1.5rem;}
强烈建议使用box-sizing:border-box.点击这里查看更多信息。
左/右内间距与最大宽度联合使用可以很容易地创建一个移动端友好的容器。
要为容器选择一个合适的宽度,既不能太大(因为太大的话读者的眼睛难以聚焦)也不能太小(这样读者的眼睛需要经常移动才可以看清)。永远记住,在进行网页字体排版的时候,没有一个适合所有字体、尺寸、行距和分辨率的铁律,你需要自己来做决定。
扩展阅读:
*{Box-sizing:Border-box}FTW
StackOverflow:IdealColumnWidthForParagraphsOnline
字体大小
使用缩放模块可以帮助你决定在你的元素上面应用怎样的font-size.缩放模块指的是依照其内容安排的一系列比较合适的字体大小的数值。
缩放模块的说明.点击此处
我们可以在编写CSS的一开始使用缩放模块,将它作为一个参考。
值的注意的是,尽管不同的字体有着不同的大写字母高度和x字母高度,可是大多数的模块化缩放工具都没有将这些考虑在内。
在你的样式表中,建议将你所使用到的缩放模块工具的配置信息写在注释之中。
响应式的缩放模块
只使用单独的一个缩放模块方案并不一定适合所有分辨率的设备,为了解决这个问题,你可以依据用户的设备的分辨率的不同提供不同的缩放方案
垂直距离
文字间的垂直距离是由line-height,margin,和padding构建出来的.
line-height不应该带有单位。比较宽的容器里面文字的行高会大一些,而那些比较窄的容器里面行高相对来说小一些会比较合适。
为那些具有单方向的文本元素添加margin属性,建议使用margin-bottom.
要遵循距离原则.
垂直节律
垂直节律是指元素之间的垂直间隔要保持一致性。这一点十分重要,它可以带给读者视觉上放松的享受,给他们一种亲近的感觉。
Imagesource建立垂直节律很简单。首先,确定你使用的基础垂直内间距和基础垂直外间距的数值。然后,为你的容器,文字性元素或者其他相关元素的单方向的外边距(或者内边距)应用这个数值。如果你需要制制造更大的间隔的话,应用这个数值的倍数就好啦!
将基础间距的数值设置成与行高相同的数值,这样你的文字就像写在一个条格纸上那样整齐,就像我们传统的印刷字体设计的那样。然而,想要文字拥有垂直节律不一定需要按照上面的方法来做,只要你设置了一个基础间距,并且使得其他间距都是由这个间距成倍的得来的,那样就可以了。
文字底部对齐基线网格
文字底部对齐基线是垂直节律的一个更为严格的实现。在网页中,文字通常在line-height间居中对齐.但对于较大的文字来说会比较讨厌,因为这样做会导致在顶部和底部留有太多的空间。在传统印刷的时候,这个问题一般会通过让文字对齐基线网格的底部得以解决。
我们也可以通过为较大的文字添加一个负的margin-top和一个较小的margin-bottom,不需要使用基线网格而解决这个问题。
图片资源为不同的字体样式、字体大小和分辨率添加一个底部对齐的基线网格并不是一个很容易的方式,所以强烈建议你使用一个字体排版基线库例如Sassline或者MegaType.
注意,垂直节律只是一个建议,而且基线网格也只是想象出来的。所以我们不需要在每个使用场合都遵循这个规律,也不用在每个元素中都去追求像素级别的完美。
扩展阅读:
WhyisVerticalRhythmanImportantTypographyPractice?
AligningtypetobaselinetherightwayusingSASS
IsWebTypographyCompletelyBroken?
Single-directionMarginDeclarations
颜色
颜色可以很大程度上的增加视觉辨识度,是字体排版中一个重要的组成部分。
不要随心所欲的挑选颜色,建议使用颜色板,建议你使用MaterialDesigncolors和FlatUIcolors中提供的颜色板进行颜色选择.
不要过度滥用一个颜色,因为这样会造成辨识度的降低,同样也不要使用很多完全不同的颜色。
遵循相似原则.
不建议使用纯黑#000作为你的正文颜色,你可以选择一个非常灰的颜色如#333.
有时候,使用透明颜色比使用浅色会更好一些,如果你深入的了解,可以点击这里。
确保文字和背景有较大的对比度,你可以使用这个对比度检测工具帮助你进行选择.
####扩展阅读:
MagicOfCSS:Color
GoogleStyle–Color
下划线
在印刷品里,永远都不要使用到下划线,因为这样做会影响文字的阅读,重点是,它很丑!PracticalTypography
一般的来说,在网页中下划线也会看起来并不美好!幸运的是,background-image就包含一个方法,它可以使得下划线变得好看一点。下面是AdamSchwartz使用Sass实现的下划线的例子:
SmartUnderline是一个简化这个工作的库。建议你只在有链接的地方使用下划线,这是大多是网站都遵循的规律,如果不这么做的话,可能会引起误解。
整体认读怎么写好看
整体认读写得好看取决于以下三个方面:排版、字体和内容。首先,排版要合理,行间距和字间距要适当,整体看起来比较舒服;其次,选择合适的字体可以让认读更美观,但需要注意不能用过于花哨的字体,会影响阅读体验;最后,内容要简练明了,语言通顺流畅,符合叙述的逻辑和结构,这样才能吸引人的眼球。综上所述,整体认读要写得好看需要在排版、字体和内容上都下功夫。
如何练出很随意但是好看的字体
要练出很随意但是好看的字体,可以尝试以下几个方法:
1.练习毛笔字:毛笔字有着自由、随意的特点,适合表现出个人风格。可以选择一些简单的汉字或者词语进行练习,并在书写时注重节奏和力度。
2.多看多模仿:观察周围环境中各种不同类型的文字,包括广告、海报、标志等等,并尝试模仿其中某些元素或风格。
3.利用线条和空间感:在书写时注意线条粗细变化和排版布局,刻意营造出视觉上舒适而又具有艺术感的效果。
4.尝试手写草稿:将需要书写的内容先以草稿形式快速地涂鸦下来,然后再慢慢调整每一个字符之间的距离和大小比例。
5.不断实践与改进:通过不断地实践与改进,在保持自己独特风格基础上不断提高自己的技能水平和审美能力。
写字整体好看的技巧
1.横画略斜,竖要写直2.笔画聚中,紧凑勿散
3.多横画平行或等距4.多竖画平行或等距
5.分清垂露竖、悬针竖6.撇捺相交,交点靠上
7.撇捺舒展,左右对称8.长横主笔舒展写长
9.长竖主笔挺拔写直10.钩类主笔要写突出
11.字头宽,要盖住下部12.字底宽,要承载上部
13.相似笔画有长有短14.相同部件注意变化
15.四点底四点要错落16.小一点的字写丰满
好了,本文到此结束,如果可以帮助到大家,还望关注本站哦!