Я создал проект и попытался настроить веб-пакет, но не мог понять, почему он не сохраняет сгенерированные файлы в папку dist
.
Структура проекта:
- / клиент
- / действия
- / активы
- другие папки
- / стили
- index.html
- index.js
- AppRouter.jsx
- / расстояние
- webpack.config.js
- package.json
Я включаю sass в компонент реагирования, а index.html помещаю в папку клиента.
(Я заменил папку src на клиентскую).
webpack.config.js
const path = require('path'),
webpack = require('webpack'),
HtmlWebpackPlugin = require('html-webpack-plugin'),
MiniCssExtractPlugin = require('mini-css-extract-plugin');
const APP_DIR = path.resolve(__dirname, 'client');
module.exports = {
entry: path.resolve(__dirname, 'client', 'index.js'),
output: {
path: path.resolve(__dirname, 'dist'),
filename: './js/bundle.js',
publicPath: './dist',
},
resolve: {
extensions: ['.js', '.jsx', '.sass']
},
devServer: {
contentBase: '/dist',
},
module: {
rules: [
{
test: /\.(js|jsx)$/,
exclude: ['/node_modules/'],
use: ['babel-loader']
},
{
//'/dist/'
test: /\.(c|sa)ss$/,
exclude: ['/node_modules/'],
use: [
{
loader: MiniCssExtractPlugin.loader,
options: {
hmr: true
},
},
"css-loader",
"sass-loader"
]
},
{
test: /\.(jpe?g|png)$/,
use: [{
loader: 'url-loader',
options: {
limit: 10000
}
}]
}
]
},
plugins: [
new HtmlWebpackPlugin({
template: path.resolve(__dirname, 'client', 'index.html'),
filename: 'index.html'
}),
new MiniCssExtractPlugin({
filename: '[name].css',
chunkFilename: '[id].css',
}),
]
};
package.json
{
"name": "stud-cit",
"version": "0.1.0",
"private": true,
"dependencies": {
"@editorjs/editorjs": "^2.12.4",
"@editorjs/header": "^2.2.3",
"@editorjs/list": "^1.3.4",
"@material-ui/core": "^3.8.3",
"@material-ui/icons": "^3.0.2",
"@material-ui/styles": "^3.0.0-alpha.8",
"ajv": "^6.6.2",
"axios": "^0.18.0",
"body-parser": "^1.19.0",
"classnames": "^2.2.6",
"cors": "^2.8.5",
"express": "^4.17.1",
"history": "^4.7.2",
"material-ui": "^1.0.0-beta.47",
"prop-types": "^15.6.2",
"react": "next",
"react-dom": "next",
"react-form-validator-core": "^0.5.1",
"react-redux": "^6.0.0",
"react-router": "^4.3.1",
"react-router-dom": "^4.3.1",
"react-scripts": "^2.1.2",
"react-vis": "^1.11.6",
"redux": "^4.0.1",
"redux-devtools-extension": "^2.13.7",
"redux-saga": "^1.0.2"
},
"scripts": {
"serve": "node ./public/build/app.min.js",
"start": "webpack-dev-server --mode development --config webpack.config.js --hot",
"lint": "./node_modules/.bin/eslint ./client/**/*.{js,jsx}",
"lint-fix": "./node_modules/.bin/eslint ./client/**/*.{js,jsx} --fix"
},
"eslintConfig": {
"extends": "react-app"
},
"browserslist": [
">0.2%",
"not dead",
"not ie <= 11",
"not op_mini all"
],
"devDependencies": {
"@babel/core": "^7.4.5",
"@babel/plugin-proposal-class-properties": "^7.4.4",
"@babel/plugin-syntax-dynamic-import": "^7.2.0",
"@babel/preset-env": "^7.4.5",
"@babel/preset-react": "^7.0.0",
"babel-loader": "^8.0.6",
"bootstrap": "^4.0.0-alpha.6",
"css-loader": "^3.0.0",
"eslint-config-airbnb": "^17.1.0",
"eslint-loader": "^2.1.1",
"eslint-plugin-import": "^2.16.0",
"eslint-plugin-jsx-a11y": "^6.2.0",
"eslint-plugin-react": "^7.12.4",
"html-webpack-plugin": "^3.2.0",
"mini-css-extract-plugin": "^0.7.0",
"node-sass": "^4.12.0",
"react-hot-loader": "^4.11.0",
"sass-loader": "^7.1.0",
"style-loader": "^0.23.1",
"url-loader": "^2.0.0",
"webpack": "^4.34.0",
"webpack-cli": "^3.3.3",
"webpack-dev-server": "^3.7.1"
},
"babel": {
"presets": [
"@babel/preset-env",
"@babel/preset-react"
],
"plugins": [
"@babel/plugin-proposal-class-properties",
"@babel/plugin-syntax-dynamic-import"
]
}
}
Не отображается ни один из сгенерированных файлов (html, css, js).