- Koa.js 教程
- Koa.js - 主页
- Koa.js - 概述
- Koa.js - 环境
- Koa.js - 你好世界
- Koa.js - 生成器
- Koa.js - 路由
- Koa.js - URL 构建
- Koa.js - HTTP 方法
- Koa.js - 请求对象
- Koa.js - 响应对象
- Koa.js - 重定向
- Koa.js - 错误处理
- Koa.js - 级联
- Koa.js - 模板
- Koa.js - 表单数据
- Koa.js - 文件上传
- Koa.js - 静态文件
- Koa.js - Cookie
- Koa.js - 会话
- Koa.js - 身份验证
- Koa.js - 压缩
- Koa.js - 缓存
- Koa.js - 数据库
- Koa.js - RESTful API
- Koa.js - 日志记录
- Koa.js - 脚手架
- Koa.js - 资源
- Koa.js 有用资源
- Koa.js - 快速指南
- Koa.js - 有用的资源
- Koa.js - 讨论
Koa.js - 压缩
压缩是节省带宽和加快网站速度的简单有效的方法。它仅与现代浏览器兼容,如果您的用户也使用旧版浏览器,则应谨慎使用。
当从服务器发送响应时,如果使用压缩,可以大大缩短加载时间。我们将使用一个名为koa-compress 的中间件来负责文件的压缩以及设置适当的标头。
继续使用以下命令安装中间件 -
$ npm install --save koa-compress
现在在您的 app.js 文件中添加以下代码 -
var koa = require('koa'); var router = require('koa-router'); var app = koa(); var Pug = require('koa-pug'); var pug = new Pug({ viewPath: './views', basedir: './views', app: app //Equivalent to app.use(pug) }); app.use(compress({ filter: function (content_type) { return /text/i.test(content_type) }, threshold: 2048, flush: require('zlib').Z_SYNC_FLUSH })); var _ = router(); //Instantiate the router _.get('/', getRoot); function *getRoot(next){ this.render('index'); } app.use(_.routes()); //Use the routes defined using the router app.listen(3000);
这使我们的压缩中间件就位。过滤选项是检查响应内容类型以决定是否压缩的功能。阈值选项是要压缩的最小响应大小(以字节为单位)。这确保我们不会压缩每一个小响应。
以下是未经压缩的响应。
以下是压缩时的类似响应。
如果您查看底部的尺寸标签,您可以很好地看到两者之间的差异。当我们压缩文件时,性能提升了 150% 以上。