A simple and reliable webpack starter kit for your web adventures needs, feat. Bootstrap-v4, JQuery or TailwindCSS
- Separated development and production webpack settings you can understand
- Sass
- ES6
- Asset loading
- CSS Vendor prefixing
- Development server
- Sourcemaps
- Favicons generation
- Production optimizations
- Mobile browser header color
- Node > 7.6
Substitute PROJECT-NAME
for your project name.
Clone the repository
git clone https://github.com/adityasonel/webpack-starter-kit PROJECT-NAME
cd PROJECT-NAME
Or you can head-start with pre setuped tailwindcss kit as
git clone --single-branch --branch tailwind-kit https://github.com/adityasonel/webpack-starter-kit PROJECT-NAME
cd PROJECT-NAME
Or you can also start with bootstrap-jquery setup kit as
git clone --single-branch --branch bootstrap-kit https://github.com/adityasonel/webpack-starter-kit PROJECT-NAME
cd PROJECT-NAME
Install npm dependencies
npm install or yarn
To start the development server
npm start
To build for production
npm run build
To preview the production build
npm run preview
If you don't support Opera Mini, browsers support the .woff format. Its newer version .woff2, is widely supported by modern browsers and can be a good alternative.
If you decide to use only this format you can load the fonts in a similar manner to images.
In your webpack.dev.js
and webpack.prod.js
add the following
module.exports = {
// ..
module: {
rules: [
// ..
{
test: /\.woff$/,
loader: "url-loader",
options: {
// Limit at 50k. Above that it emits separate files
limit: 50000,
// url-loader sets mimetype if it's passed.
// Without this it derives it from the file extension
mimetype: "application/font-woff",
// Output below fonts directory
name: "./fonts/[name].[ext]",
},
},
// ..
],
},
// ..
};
And let's say your font is in the folder assets
with the name pixel.woff
You can add it and use it in index.scss
as
@font-face {
font-family: "Pixel";
src: url("./../assets/pixel.woff") format("woff");
}
.body {
font-family: "Pixel", sans-serif;
}
If you would like to support all kinds of font types, remove the woff rule we previously added to webpack.dev.js
and webpack.prod.js
and add the following
module.exports = {
// ..
module: {
rules: [
// ..
{
test: /\.(ttf|eot|woff|woff2)$/,
loader: "file-loader",
options: {
name: "fonts/[name].[ext]",
},
},
// ..
],
},
// ..
};
And assuming you have your fonts in the directory assets
with names pixel.woff
, pixel.ttf
, pixel.eot
, etc.
You can add it and use it in index.scss
as
@font-face {
font-family: "Pixel";
src: url("./../assets/pixel.woff2") format("woff2"), url("./../assets/pixel.woff") format("woff"),
url("./../assets/pixel.eot") format("embedded-opentype"), url("./../assets/pixel.ttf")
format("truetype");
/* Add other formats as you see fit */
}
You can require an image from JavaScript like
const myImage = require("./assets/icon.png");
If the image size in bytes is smaller than 8192
you, myImage
will be a string with the encoded image path such as
data:image/svg+xml;base64,bW9kdWxlLmV4cG9ydHMgPSBfX3dlYnBhY2tfcHVibGljX3BhdGhfXyArICJhc3NldHMvaW1hZ2VzL3RpY2stQ3lydkhSdi5zdmciOw==
If the image size is larger than 8192
it will be a string with the url to the image such as
src/assets/icon.png?hash=5b1f36bc41ab31f5b801
This limit is set so images like icons are not loaded through a request but you can force the loader to give you image urls always by doing the following but should not be necessary. The limit works 90% of the time.
const myImage = require("!!url!/assets/icon.png");
If you would like to include an image on your index.html
file, place the path of the image in a webpack require statement<%= require(imagePath) %>
.
<img class="splash-title__img"
src="<%= require('./src/assets/logo-on-dark-bg.png') %>"
alt="webpack logo"></a>
Start the development server and voilà
.
npm start
To build for production
npm run build
To preview the production build
npm run preview
Author Aditya Sonel