0
# URL Loader
1
2
URL Loader is a webpack loader that transforms files into base64 URIs for efficient bundling and deployment. It works as an intelligent alternative to file-loader by converting small files directly into data URLs while falling back to file-loader for larger files that exceed a configurable size limit.
3
4
## Package Information
5
6
- **Package Name**: url-loader
7
- **Package Type**: npm
8
- **Language**: JavaScript (Node.js)
9
- **Installation**: `npm install url-loader`
10
- **Webpack Versions**: 4.x and 5.x
11
- **Node.js**: >= 10.13.0
12
13
## Core Imports
14
15
For webpack configuration:
16
17
```javascript
18
// webpack.config.js
19
module.exports = {
20
module: {
21
rules: [
22
{
23
test: /\.(png|jpg|gif|svg)$/i,
24
use: [
25
{
26
loader: 'url-loader',
27
options: {
28
limit: 8192,
29
},
30
},
31
],
32
},
33
],
34
},
35
};
36
```
37
38
For programmatic usage (rare):
39
40
```javascript
41
const urlLoader = require('url-loader');
42
```
43
44
## Basic Usage
45
46
URL Loader is primarily used through webpack configuration. It automatically processes matched files during the webpack build process:
47
48
```javascript
49
// webpack.config.js
50
module.exports = {
51
module: {
52
rules: [
53
{
54
test: /\.(png|jpg|gif)$/i,
55
use: [
56
{
57
loader: 'url-loader',
58
options: {
59
limit: false, // Always use base64
60
},
61
},
62
],
63
},
64
{
65
test: /\.svg$/i,
66
use: [
67
{
68
loader: 'url-loader',
69
options: {
70
limit: 8192, // 8KB threshold
71
mimetype: 'image/svg+xml',
72
encoding: 'base64',
73
},
74
},
75
],
76
},
77
],
78
},
79
};
80
```
81
82
Application code using processed assets:
83
84
```javascript
85
import logoImage from './assets/logo.png'; // Will be base64 data URI if under limit
86
import iconSvg from './assets/icon.svg'; // Will be base64 data URI if under limit
87
88
// logoImage and iconSvg contain either:
89
// - ... (if under limit)
90
// - /static/media/logo.abc123.png (if over limit, handled by fallback)
91
```
92
93
## Architecture
94
95
URL Loader operates as a webpack loader with the following key components:
96
97
- **Main Loader Function**: Processes file content and determines transformation strategy
98
- **Size-based Decision Logic**: Compares file size against configurable limit
99
- **Data URI Generation**: Converts files to base64 or other encoding formats
100
- **Fallback System**: Delegates to another loader (typically file-loader) for large files
101
- **Configuration Validation**: Validates all options against JSON schema
102
103
## Capabilities
104
105
### Main Loader Function
106
107
The primary webpack loader function that processes file content.
108
109
```javascript { .api }
110
/**
111
* Main webpack loader function - called by webpack during build
112
* @param {Buffer|string} content - File content to process
113
* @returns {string} JavaScript module code containing the data URI or fallback result
114
*/
115
function loader(content) {}
116
117
// Raw mode flag - indicates loader should receive Buffer instead of string
118
loader.raw = true;
119
```
120
121
### Configuration Options
122
123
Complete configuration interface for the loader options.
124
125
```javascript { .api }
126
interface LoaderOptions {
127
/** Maximum file size for base64 transformation */
128
limit?: boolean | number | string;
129
/** Encoding method for data URI generation */
130
encoding?: boolean | "utf8" | "utf16le" | "latin1" | "base64" | "hex" | "ascii" | "binary" | "ucs2";
131
/** MIME type for the generated data URI */
132
mimetype?: boolean | string;
133
/** Custom data URI generator function */
134
generator?: (content: Buffer, mimetype: string, encoding: string, resourcePath: string) => string;
135
/** Alternative loader for files exceeding the limit */
136
fallback?: string | FallbackConfig;
137
/** Generate ES module syntax instead of CommonJS */
138
esModule?: boolean;
139
}
140
141
interface FallbackConfig {
142
/** Fallback loader name */
143
loader: string;
144
/** Options to pass to fallback loader */
145
options?: object | string;
146
}
147
```
148
149
### Limit Configuration
150
151
Controls when files are transformed to base64 vs delegated to fallback loader.
152
153
```javascript { .api }
154
// Boolean mode
155
limit: true // Always transform to base64
156
limit: false // Never transform, always use fallback
157
158
// Numeric mode (bytes)
159
limit: 8192 // Transform files <= 8KB
160
limit: "10kb" // Transform files <= 10KB (string format)
161
```
162
163
**Usage Examples:**
164
165
```javascript
166
// Always convert to base64 (no size limit)
167
{
168
loader: 'url-loader',
169
options: {
170
limit: true
171
}
172
}
173
174
// Never convert to base64 (always use fallback)
175
{
176
loader: 'url-loader',
177
options: {
178
limit: false
179
}
180
}
181
182
// Size-based conversion (8KB threshold)
183
{
184
loader: 'url-loader',
185
options: {
186
limit: 8192
187
}
188
}
189
```
190
191
### MIME Type Configuration
192
193
Controls the MIME type included in generated data URIs.
194
195
```javascript { .api }
196
// Boolean mode
197
mimetype: true // Auto-detect from file extension
198
mimetype: false // Omit MIME type from data URI
199
200
// String mode
201
mimetype: "image/png" // Use specific MIME type
202
```
203
204
**Usage Examples:**
205
206
```javascript
207
// Auto-detect MIME type
208
{
209
loader: 'url-loader',
210
options: {
211
mimetype: true // Uses mime-types library
212
}
213
}
214
215
// Specific MIME type
216
{
217
loader: 'url-loader',
218
options: {
219
mimetype: 'image/svg+xml'
220
}
221
}
222
223
// No MIME type in data URI
224
{
225
loader: 'url-loader',
226
options: {
227
mimetype: false
228
}
229
}
230
```
231
232
### Encoding Configuration
233
234
Specifies how file content is encoded in the data URI.
235
236
```javascript { .api }
237
// Boolean mode
238
encoding: true // Use base64 encoding
239
encoding: false // No encoding (raw content)
240
241
// String mode - Node.js buffer encodings
242
encoding: "base64" | "utf8" | "utf16le" | "latin1" | "hex" | "ascii" | "binary" | "ucs2"
243
```
244
245
**Usage Examples:**
246
247
```javascript
248
// Base64 encoding (default)
249
{
250
loader: 'url-loader',
251
options: {
252
encoding: 'base64'
253
}
254
}
255
256
// UTF-8 encoding for text files
257
{
258
loader: 'url-loader',
259
options: {
260
encoding: 'utf8'
261
}
262
}
263
264
// No encoding
265
{
266
loader: 'url-loader',
267
options: {
268
encoding: false
269
}
270
}
271
```
272
273
### Custom Generator Function
274
275
Allows custom data URI generation logic.
276
277
```javascript { .api }
278
/**
279
* Custom generator function for creating data URIs
280
* @param {Buffer} content - File content as Buffer
281
* @param {string} mimetype - Resolved MIME type
282
* @param {string} encoding - Resolved encoding method
283
* @param {string} resourcePath - Full file path
284
* @returns {string} Custom data URI string
285
*/
286
type GeneratorFunction = (
287
content: Buffer,
288
mimetype: string,
289
encoding: string,
290
resourcePath: string
291
) => string;
292
```
293
294
**Usage Examples:**
295
296
```javascript
297
{
298
loader: 'url-loader',
299
options: {
300
generator: (content, mimetype, encoding, resourcePath) => {
301
// Custom logic for HTML files
302
if (/\.html$/i.test(resourcePath)) {
303
return `data:${mimetype},${content.toString()}`;
304
}
305
306
// Default behavior for other files
307
return `data:${mimetype}${encoding ? `;${encoding}` : ''},${content.toString(encoding)}`;
308
}
309
}
310
}
311
```
312
313
### Fallback Loader Configuration
314
315
Configures alternative loader for files exceeding the size limit.
316
317
```javascript { .api }
318
// String format
319
fallback: "file-loader"
320
fallback: "responsive-loader"
321
322
// Object format with options
323
fallback: {
324
loader: "file-loader",
325
options: {
326
name: "[name].[hash:8].[ext]",
327
outputPath: "images/"
328
}
329
}
330
```
331
332
**Usage Examples:**
333
334
```javascript
335
// Simple fallback
336
{
337
loader: 'url-loader',
338
options: {
339
limit: 8192,
340
fallback: 'file-loader'
341
}
342
}
343
344
// Fallback with custom options
345
{
346
loader: 'url-loader',
347
options: {
348
limit: 8192,
349
fallback: {
350
loader: 'file-loader',
351
options: {
352
name: '[path][name].[ext]',
353
outputPath: 'assets/'
354
}
355
}
356
}
357
}
358
359
// Advanced fallback
360
{
361
loader: 'url-loader',
362
options: {
363
limit: 8192,
364
fallback: require.resolve('responsive-loader'),
365
quality: 85 // This option passes through to responsive-loader
366
}
367
}
368
```
369
370
### ES Module Configuration
371
372
Controls output module format.
373
374
```javascript { .api }
375
esModule: boolean // Default: true
376
```
377
378
**Usage Examples:**
379
380
```javascript
381
// ES module output (default)
382
{
383
loader: 'url-loader',
384
options: {
385
esModule: true
386
}
387
}
388
// Generates: export default "data:image/png;base64,..."
389
390
// CommonJS output
391
{
392
loader: 'url-loader',
393
options: {
394
esModule: false
395
}
396
}
397
// Generates: module.exports = "data:image/png;base64,..."
398
```
399
400
## Error Handling
401
402
URL Loader validates all options and throws errors for:
403
404
- **Invalid Options**: Schema validation failures for malformed configuration
405
- **Missing Fallback**: When fallback loader cannot be resolved or loaded
406
- **Encoding Errors**: When specified encoding is not supported by Node.js
407
- **File System Errors**: When file cannot be read during processing
408
409
Common error scenarios:
410
411
```javascript
412
// Invalid limit type
413
{
414
loader: 'url-loader',
415
options: {
416
limit: {} // Error: limit must be boolean, number, or string
417
}
418
}
419
420
// Invalid encoding
421
{
422
loader: 'url-loader',
423
options: {
424
encoding: 'invalid' // Error: unsupported encoding
425
}
426
}
427
428
// Missing fallback loader
429
{
430
loader: 'url-loader',
431
options: {
432
fallback: 'nonexistent-loader' // Error: cannot resolve loader
433
}
434
}
435
```
436
437
## Dependencies
438
439
### Required Dependencies
440
441
- **loader-utils** (^2.0.0): Webpack loader utilities for option parsing
442
- **mime-types** (^2.1.27): MIME type detection from file extensions
443
- **schema-utils** (^3.0.0): JSON schema validation for loader options
444
445
### Peer Dependencies
446
447
- **webpack** (^4.0.0 || ^5.0.0): Required webpack version
448
- **file-loader** (*): Optional, used as default fallback loader
449
450
### Runtime Requirements
451
452
- **Node.js**: >= 10.13.0
453
- **Environment**: Node.js server-side (webpack build process)
454
455
## CommonJS and ES Module Support
456
457
URL Loader provides both CommonJS and ES module interfaces:
458
459
```javascript { .api }
460
// CommonJS (main entry - dist/cjs.js)
461
const urlLoader = require('url-loader');
462
urlLoader.raw; // true
463
464
// ES Module (source - src/index.js)
465
import urlLoader, { raw } from 'url-loader/src';
466
```
467
468
Note: The ES module version is the source code and requires transpilation for older Node.js versions.