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);

これにより、圧縮ミドルウェアが配置されます。フィルタオプションは、応答コンテンツタイプをチェックして、圧縮するかどうかを決定する関数です。しきい値オプションは、圧縮する最小応答サイズ(バイト単位)です。これにより、小さな応答をすべて圧縮する必要がなくなります。

以下は、圧縮なしの応答です。

以下は、圧縮による同様の応答です。

下部の[サイズ]タブを見ると、2つの違いがよくわかります。ファイルを圧縮すると、150%以上の改善が見られます。