资讯中心

网站优化

首页 >技术资讯 > 网站优化 >

优化CSS并加速网站的21种方法

  优化CSS需要一个多维的方法。虽然手工编写的代码可以使用各种技术进行简化,但是手工检查框架代码是低效的。在这些情况下,使用自动化的简化会产生更好的结果。

  下面的步骤将带我们进入CSS优化的世界。并不是每一个都可以直接应用到你的项目中,但是一定要记住它们。

  01.使用简写

  使用缩写语句,如下面所示的margin声明,可以从根本上减小CSS文件的大小。在google上搜索CSSShorthand可以找到许多其他的速记形式。

  p{margin-top:1px;

  margin-right:2px;

  margin-bottom:3px;

  margin-left:4px;}

  p{margin:1px2px3px4px;}

  02.查找并删除未使用的CSS

  删除不必要的部分CSS,j显然会加快网页的加载速度。谷歌的Chrome浏览器有这种开箱即用的功能。只需转到查看>开发人员>开发人员工具,并在最近的版本中打开Sources选项卡,然后打开命令菜单。然后,选择ShowCoverage,在Coverageanalysis窗口中高亮显示当前页面上未使用的代码,让您大开眼界。

  03.以更便捷的方式做到这一点

  在逐行分析中导航并不一定便捷,使用谷歌浏览器的Audits就可以快速帮我们分析,使用方式,打开开发者工具,点击Audits栏位,点击Runaudits后就开始分析结果。

  04.注意这些问题

  加载外部样式表需要花费时间,这是由于延迟造成的——因此,可以把最关键的代码位放在head中。但是,请确保不要做得过火,记住,执行维护任务的人员也必须读取代码。

  .blue{color:blue;}

  Hello,world!

  06.允许反并行解析

  @import将CSS样式方便添加代码中。遗憾的是,这些好处并不是没有代价的:由于@import可以嵌套,因此无法并行解析它们。更并行的方法是使用一系列标记,浏览器可以立即获取这些标记。

  @importurl("a.css");

  @importurl("b.css");

  @importurl("c.css");

  07.用CSS替换图片

  几年前,一套半透明的png在网站上创建半透明效果是司空见惯的。现在,CSS过滤器提供了一种节省资源的替代方法。例如,以下这个代码片段可以确保所讨论的图片显示为其自身的灰度版本。

  img{

  -webkit-filter:grayscale(100%);

  /*oldsafari*/

  filter:grayscale(100%);

  }

  08.使用颜色快捷方式

  常识告诉我们,六位数的颜色描述符是表达颜色最有效的方式。事实并非如此——在某些情况下,速记描述或颜色名称可以更短。

  target{background-color:#ffffff;}

  target{background:#fff;}

  09.删除不必要的零和单位

  CSS支持多种单位和数字格式。它们是一个值得感谢的优化目标——可以删除尾随和跟随的零,如下面的代码片段所示。此外,请记住,零始终是零,添加维度不会为包含的信息附带价值。

  padding:0.2em;

  margin:20.0em;

  avalue:0px;

  padding:.2em;

  margin:20em;

  avalue:0;

  10.消除过多分号

  这种优化需要谨慎,因为它会影响代码的更改。CSS的规范允许省略属性组中的最后一个分号。由于这种优化方法所节省的成本很小,所以我们主要针对那些正在开发自动优化的程序员说明这一点。

  p{...font-size:1.33em}

  11.使用纹理图集

优化CSS并加速网站的21种方法

  由于协议开销的原因,加载多个小图片的效率很低。CSS精灵将一系列小图片组合成一个大的PNG文件,然后通过CSS规则将其分解。TexturePacker

  等程序大大简化了创建过程。

  .download{

  width:80px;

  height:31px;

  background-position:-160px-160px

  }

  .download:hover{

  width:80px;

  height:32px;

  background-position:-80px-160px

  }

  12.省略px

  提高性能的一个简单方法是使用CSS标准的一个特性。为0的数值默认单位是px——删除px可以为每个数字节省两个字节。

  h2{padding:0px;margin:0px;}

  h2{padding:0;margin:0}

  13.避免需要性能要求的属性

  分析表明,一些标签比其他标签更昂贵。以下这些解析会影响性能—如果在没有必要的情况,尽量不要使用它们。

  border-radius

  box-shadow

  transform

  filter

  :nth-child

  position:fixed;

  14.删除空格

  空格——考虑制表符、回车符和空格——使代码更容易阅读,但从解析器的角度看,它没有什么用处。在发布前删除它们,更好的方法是将此任务委托给shell脚本或类似的工具。

  15.删除注释

  注释对编译器也没有任何作用。创建一个自定义解析器,以便在发布之前删除它们。这不仅节省了带宽,而且还确保攻击者和克隆者更难理解手头代码背后的思想。

  16.使用自动压缩

  Yahoo的用户体验团队创建了一个处理许多压缩任务的应用程序。它以JAR文件的形式发布,可在此处获得

  并且可以使用所选的JVM运行。

  java-jaryuicompressor-x.y.z.jar

  Usage:java-jaryuicompressor-x.y.z.jar

  [options][inputfile]

  GlobalOptions

  -h,--helpDisplaysthis

  information

  --typeSpecifiesthe

  typeoftheinputfile

  17.在NPM运行它

  如果你希望将产品集成到Node.JS中,请访问

  npmjs.com/package/yuicompressor。维护不良的存储库包含一组包装器文件和JavaScriptAPI。

  varcompressor=require('yuicompressor');

  compressor.compress('/path/to/

  fileorStringofJS',{

  //CompressorOptions:

  charset:'utf8',

  type:'js',

  18.保持Sass的检查

  虽然CSS选择器的性能不像几年前那么重要(请参阅参考资料),但是像Sass这样的框架有时会产生非常复杂的代,不时查看输出文件,并考虑优化结果的方法。

  什么是Sass?(

  )

  19.设置缓存

  有句老话说,最快的文件永远不会通过网络发送。让浏览器缓存请求有效地实现这一点。遗憾的是,缓存头的设置必须在服务器上进行。充分上面讲的的两个Chrome工具,它们提供了一种快速分析更改结果的方法。

  20.打破缓存

  设计人员通常不喜欢缓存,因为他们担心浏览器会缓存上次的样式表。解决这个问题的一个简单方法是包含带有文件名的标记。遗憾的是,由于一些代理拒绝缓存具有“动态”路径的文件,此步骤所附带的代码中概述的方案并不适用于所有地方。

  21.不要忘记基础知识

  优化CSS只是游戏的一部分。如果你的服务器不使用HTTP/2和gzip压缩,那么在数据传输期间会损失很多时间。幸运的是,解决这两个问题通常很简单。我们的示例显示了对常用Apache服务器的一些调整。如果您发现自己在一个不同的系统上,只需参考服务器文档即可。

  pico/etc/httpd/conf/httpd.conf

  AddOutputFilterByTypeDEFLATEtext/html

  AddOutputFilterByTypeDEFLATEtext/css

顶部