webpack
webpack-cli
webpack-dev-server
- to serve & auto-reload webpackwebpack-merge
- to split configuration into dev/prod config files
eslint
eslint-loader
- webpack eslint loadereslint-plugin-import
- to show what sort of dependency do we have dev/prod in package.jsoneslint-config-airbnb-base
- airbnb preset for eslint
@babel/core
@babel/preset-env
babel-loader
As of Babel 7.4.0, this package has been deprecated in favor of directly including core-js/stable (to polyfill ECMAScript features) and regenerator-runtime/runtime (needed to use transpiled generator functions) https://babeljs.io/docs/en/babel-polyfill/#usage-in-node-browserify-webpack
core-js
regenerator-runtime
css-loader
mini-css-extract-plugin
style-loader
sass-loader
node-sass
autoprefixer
- to perform browser compatibilitycssnano
- to compress the css code + removes commentspostcss-loader
html-webpack-plugin
- to insert 'styles.css' & 'scripts.js' into html tags automatically
file-loader
- to process other files (eg. images, .png, .gif)copy-webpack-plugin
- just to copy files with directories from -> to
clean-webpack-plugin
- to clean the/dist
folder before each build
- allows to see exactly the same filename as the development (not app.js, but script.js)
{
mode: 'development',
devtool: 'cheap-module-eval-source-map',
devServer: {
port: 8081,
overlay: true,
},
plugins: [
new Webpack.SourceMapDevToolPlugin({
filename: '[file].map',
})
]
}
# Download repository:
git clone https://github.com/kamikozz/webpack-template webpack-template
# Go to the app:
cd webpack-template
# Install dependencies:
# 1. from package.json (with the given versions)
npm install
# 2. with newest versions
npm install --save-dev @babel/core @babel/preset-env autoprefixer babel-eslint babel-loader clean-webpack-plugin copy-webpack-plugin core-js css-loader css-mqpacker cssnano eslint eslint-config-airbnb-base eslint-loader eslint-plugin-import file-loader html-webpack-plugin mini-css-extract-plugin node-sass path postcss-loader regenerator-runtime sass-loader style-loader webpack webpack-cli webpack-dev-server webpack-merge
# Server with hot reload at http://localhost:8081/
npm run dev
# Output will be at dist/ folder
npm run build
src/index.html
- main app HTMLsrc/assets/scss
- put custom app SCSS styles here. Don't forget to import them inindex.js
src/assets/css
- the same as above but CSS here. Don't forget to import them inindex.js
src/assets/img
- put images here. Don't forget to use correct path:assets/img/some.jpg
src/js
- put custom app scripts heresrc/index.js
- main app file where you include/import all required libs and init appsrc/components
- folder with custom.vue
componentssrc/store
- app store for vuestatic/
- folder with extra static assets that will be copied into output folder
Easy way to move all files. Default:
const PATHS = {
// Path to main app dir
src: path.join(__dirname, '../src'),
// Path to Output dir
dist: path.join(__dirname, '../dist'),
// Path to Second Output dir (js/css/fonts etc folder)
assets: 'assets/'
}
Change any folders:
const PATHS = {
// src must be src
src: path.join(__dirname, '../src'),
// dist to public
dist: path.join(__dirname, '../public'),
// assets to static
assets: 'static/'
}
- Install libs
- Import libs in
./index.js
// React example
import React from 'react'
// Bootstrap example
import Bootstrap from 'bootstrap/dist/js/bootstrap.min.js'
import 'bootstrap/dist/js/bootstrap.min.js'
- Install libs
- Go to
/assets/scss/utils/libs.scss
- Import libs in node modules
// Sass librarys example:
@import '../../node_modules/spinners/stylesheets/spinners';
// CSS librarys example:
@import '../../node_modules/flickity/dist/flickity.css';
- Create another js module in
./js/
folder - Import modules in
./js/index.js
file
// another js file for example
import './common.js'
- .html dir:
./src
- Configurations: in
./build/webpack.base.conf.js
const PAGES_DIR = PATHS.src
Usage:
All files must be created in the ./src
folder.
Example:
./src/index.html
./src/about.html
Example for ./src/pages
:
- Create folder for all html files in
./src
. Be like:./src/pages
- Change
./build/webpack.base.conf.js
const PAGES_DIR:
// Old path
// const PAGES_DIR = PATHS.src
// Your new path
const PAGES_DIR = `${PATHS.src}/pages`
- Rerun webpack dev server
Usage:
All files must be created in the ./src/pages
folder.
Example:
./src/pages/index.html
./src/pages/about.html
Automatic creation any html pages:
- Create another html file in
./src
(main folder) - Open new page
http://localhost:8081/about.html
(Don't forget to RERUN dev server) See more - commit
Manual (not Automaticlly) creation any html pages (Don't forget to RERUN dev server and COMMENT lines above)
- Create another html file in
./src
(main folder) - Go to
./build/webpack.base.conf.js
- Comment lines above (create automaticlly html pages)
- Create new page in html:
new HtmlWebpackPlugin({
template: `${PAGES_DIR}/index.html`,
filename: './index.html',
inject: true
}),
new HtmlWebpackPlugin({
template: `${PAGES_DIR}/another.html`,
filename: './another.html',
inject: true
}),
- Open new page
http://localhost:8081/about.html
(Don't forget to RERUN dev server)
Сombine the first method and the second. Example:
...PAGES.map(page => new HtmlWebpackPlugin({
template: `${PAGES_DIR}/${page}`,
filename: `./${page}`
})),
new HtmlWebpackPlugin({
template: `${PAGES_DIR}/about/index.html`,
filename: './about/index.html',
inject: true
}),
new HtmlWebpackPlugin({
template: `${PAGES_DIR}/about/portfolio.html`,
filename: './about/portfolio.html',
inject: true
}),
Сhoose one of the ways:
- Handle menthod,
- Use mixin;
Add @font-face in /assets/scss/utils/fonts.scss
:
// Example with Helvetica
@font-face {
font-family: "Helvetica-Base";
src: url('/assets/fonts/Helvetica/Base/Helvetica-Base.eot'); /* IE9 Compat Modes */
src: url('/assets/fonts/Helvetica/Base/Helvetica-Base.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
url('/assets/fonts/Helvetica/Base/Helvetica-Base.woff') format('woff'), /* Pretty Modern Browsers */
url('/assets/fonts/Helvetica/Base/Helvetica-Base.ttf') format('truetype'), /* Safari, Android, iOS */
url('/assets/fonts/Helvetica/Base/Helvetica-Base.svg') format('svg'); /* Legacy iOS */
}
Add vars for font in /assets/scss/utils/vars.scss
:
$mySecontFont : 'Helvetica-Base', Arial, sans-serif;
By default template support only modern format fonts: .woff, .woffs;
If ypu need svg or more formaths use another mixin in src/assets/scss/utils/mixin.scss
Usage:
- Put your font to
src/assets/fonts/FOLDERNAME/FONTNAME
. FOLLOW: Files Required: Example:.woff, .woffs
formats; - Go to
fonts.scss
; - Use mixin
Example:
@include font-face("OpenSans", "../fonts/OpenSans/opensans");
, Example 2:@include font-face("OpenSans", "../fonts/OpenSans/opensansItalic", 400, italic);
.
Copyright (c) 2020