Join files on a fly to reduce requests count.
npm i join-io --save
join-io it's middleware that works with streams: open files and pipe them to response one-by-one,
when everything is done, stream is closing. join-io based on readPipe function of files-io.
jsDelivr works in similar way: load Multiple files with a single HTTP request.
Join-io could be used as express middleware.
<link rel="/join:/css/normilize.css:/css/style.css">
<script src="/join:/lib/client.js:/lib/util.js:/lib/jquery.js"></script>You could build join urls dynamically. Load /join/join.js library for this purpose.
<script src="/join/join.js"></script>
<script>
join(['lib/client', 'lib/util.js']);
</script>To decrease requests count you could make /join/join.js part of request:
<script src="/join:/lib/client.js:/lib/util.js:/join/join.js"></script>Instead of /join you could use any prefix you like (don't forget to set it on the server side).
const join = require('join-io');
const http = require('http');
const express = require('express');
const app = express();
const server = http.createServer(app);
const port = 1337;
const ip = '0.0.0.0';
app.use(join({
dir: __dirname,
prefix: '/join', /* default */
}));
app.use(express.static(__dirname));
server.listen(port, ip);MIT