@rotFRONT1

Как разбить index.js на несколько файлов в webpack при сборке проекта?

Если правильно понимаю в файле webconfig.config.js есть так называемая точка входа index.js

При разработке в нее импортируются все скрипты, библиотеки на пример jquery, различные плагины.

При сборке для передачи заказчику, все это находится в одном едином файле.

Как сделать так, что бы каждый плагин располагался в отдельном файле? Это требования pagespeed при проверке сайта на проблемы скорости "Рекомендуем сократить время на обработку, компиляцию и выполнение скриптов JS. Для этого вы можете разбить код JS на небольшие фрагменты. "

index.js
import './fonts/stylesheet.scss';
import $ from "jquery";
import * as AOS from 'aos/dist/aos.js';
import rallax from 'rallax.js'
import 'aos/dist/aos.css';
import { Fancybox } from '@fancyapps/ui';
import "@fancyapps/ui/dist/fancybox/fancybox.css";
import Swiper from 'swiper';
import { Navigation, Pagination, Grid } from 'swiper/modules';
import 'swiper/css';
import 'swiper/css/grid';
import 'swiper/css/navigation';
import 'swiper/css/pagination';
import './scss/styles.scss';

// далее кастомный код, инициализации и прочее


Есть webconfig.config.js
const HtmlWebpackPlugin = require('html-webpack-plugin');
const path = require('path');
const FileManagerPlugin = require('filemanager-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const ImageMinimizerPlugin = require('image-minimizer-webpack-plugin');
const ImageminWebpWebpackPlugin = require("imagemin-webp-webpack-plugin");
const CopyWebpackPlugin = require("copy-webpack-plugin");



module.exports = {
	cache: true,
	entry: path.join(__dirname, 'src', 'index.js'),
	output: {
		path: path.join(__dirname, 'dist'),
		filename: 'index.js',
		assetModuleFilename: path.join('images', '[name][ext]'),
	},
	module: {
		rules: [
			{
				test: /\.js$/,
				use: 'babel-loader',
				exclude: /node_modules/,
			},
			{
				test: /\.pug$/,
				loader: 'pug-loader',
			},
			{
				test: /\.(scss|css)$/,
				// use: [MiniCssExtractPlugin.loader, 'css-loader', 'postcss-loader', 'sass-loader'],
				use: [MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader'],
			},
			{
				test: /\.(png|svg|jpg|jpeg|webp|mp4)$/i,
				type: 'asset/resource',
				generator: {
					filename: path.join('assets/images', '[name][ext]'),
				},
			},
			{
				test: /\.svg$/,
				type: 'asset/resource',
				generator: {
					filename: path.join('assets/icons', '[name][ext]'),
				},
			},
			{
				test: /\.(woff2?|eot|ttf|otf)$/i,
				type: 'asset/resource',
				generator: {
					filename: 'assets/fonts/[name][ext]'
				}
			},
		],
	},
	plugins: [
		new HtmlWebpackPlugin({
			template: path.join(__dirname, 'src', 'pug/index.pug'),
			filename: 'index.html',
		}),

		new FileManagerPlugin({
			events: {
				onStart: {
					delete: ['dist'],
				},
				onEnd: {
					copy: [
						{
							source: path.join('src', 'static'),
							destination: 'dist/static',
						},
					],
				},
			}
		}),
		new MiniCssExtractPlugin({
			filename: '[name].css',
		}),
		new CopyWebpackPlugin({
			patterns: [{
				from: path.resolve(__dirname, 'src/images/'),
				to: path.resolve(__dirname, 'dist/assets/images')
			}]
		}),
	],
	devServer: {
		watchFiles: path.join(__dirname, 'src'),
		port: 9001,
	},
	optimization: {
		minimizer: [
			new ImageminWebpWebpackPlugin()
		]
	},
	performance: {
		hints: false,
		maxEntrypointSize: 512000,
		maxAssetSize: 512000
	}
};
  • Вопрос задан
  • 75 просмотров
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы