File Loader
Instructs webpack to emit the required object as file and to return its public url.
Install
npm install --save-dev file-loader
Usage
By default the filename of the resulting file is the MD5 hash of the file's contents
with the original extension of the required resource.
var url = require("file-loader!./file.png");
By default a file is emitted, however this can be disabled if required (e.g. for server
side packages).
var url = require("file-loader?emitFile=false!./file.png");
Filename templates
You can configure a custom filename template for your file using the query parameter name
. For instance, to copy a file from your context
directory into the output directory retaining the full directory structure, you might use ?name=[path][name].[ext]
.
By default, the path and name you specify will output the file in that same directory and will also use that same URL path to access the file.
You can specify custom output and public paths by using the outputPath
, publicPath
and useRelativePath
query name parameters:
use: "file-loader?name=[name].[ext]&publicPath=assets/foo/&outputPath=app/images/"
useRelativePath
should be true
if you wish to generate relative URL to the each file context
{
loader: 'file-loader',
query: {
useRelativePath: process.env.NODE_ENV === "production"
}
}
Filename template placeholders
[ext]
the extension of the resource[name]
the basename of the resource[path]
the path of the resource relative to the context
query parameter or option.[hash]
the hash of the content, hex
-encoded md5
by default[<hashType>:hash:<digestType>:<length>]
optionally you can configure
- other
hashType
s, i. e. sha1
, md5
, sha256
, sha512
- other
digestType
s, i. e. hex
, base26
, base32
, base36
, base49
, base52
, base58
, base62
, base64
- and
length
the length in chars
[N]
the N-th match obtained from matching the current file name against the query param regExp
Examples
require("file-loader?name=js/[hash].script.[ext]!./javascript.js");
require("file-loader?name=html-[hash:6].html!./page.html");
require("file-loader?name=[hash]!./flash.txt");
require("file-loader?name=[sha512:hash:base64:7].[ext]!./image.png");
require("file-loader?name=img-[sha512:hash:base64:7].[ext]!./image.jpg");
require("file-loader?name=picture.png!./myself.png");
require("file-loader?name=[path][name].[ext]?[hash]!./dir/file.png")
Contributing
Don't hesitate to create a pull request. Every contribution is appreciated. In development you can start the tests by calling npm test
.
Maintainers
LICENSE
MIT