@Evelate

Почему Webpack экспортирует весь js файл?

Настройки

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
const TerserPlugin = require("terser-webpack-plugin");

module.exports = {
  mode: 'production',
  entry: {
    'main': './src/main/main.js',
    'page2': './src/main/second.js'
  },
  output: {
    path: path.resolve(__dirname, 'public'),
    publicPath: '/public/',
    filename: './[name].js',
  },
  optimization: {
    usedExports: true,
    minimize: true,
    minimizer: [new TerserPlugin()],
  },
  plugins: [
    new HtmlWebpackPlugin({
      inject: false,
      chunks: ['main'],
      filename: "index.html",
      template: 'index.html',
    }),
    new HtmlWebpackPlugin({
      inject: false,
      chunks: ['page2'],
      filename: 'pages/second.html',
      template: 'pages/second.html',
    }),
    new CleanWebpackPlugin(),
  ],
  module: {
    rules: [
      {
        test: /\.(jpg|png|jpe?g|gif)$/i,
        loader: 'file-loader',
        options: {
          name: '[path][name].[ext]',
          // publicPath: 'file:///android_asset/Game/',
        },
      },
      {
        type: 'javascript/auto',
        test: /\.(json)/,
        exclude: /(node_modules|bower_components)/,
        loader: 'file-loader',
        options: {
          name: '[path][name].[ext]',
          // publicPath: 'file:///android_asset/Game/',
        },
      },
    ],
  },
  performance: {
    maxEntrypointSize: 1024000,
    maxAssetSize: 1024000
  },
  devServer: {
    publicPath: '/public/',

    inline:true,
    stats:"errors-only",

    compress: true,
    port: 9000,
    hot: true,
    open: true,
  },
}


json
"scripts": {
    "build": "webpack --config webpack.config.js",
    "start": "webpack-dev-server --mode development",
    "format": "prettier --write '**/*.js'"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "dependencies": {
    "three": "^0.115.0"
  },
  "devDependencies": {
    "clean-webpack-plugin": "^4.0.0",
    "file-loader": "^6.2.0",
    "html-webpack-plugin": "^4.5.2",
    "prettier": "^2.0.4",
    "terser-webpack-plugin": "^4.2.3",
    "webpack": "^4.42.1",
    "webpack-cli": "^3.3.11",
    "webpack-dev-server": "^3.11.0"
  }



файл_1
import test from './test.js';
test();


файл_2
export default function test() {
  console.log('hi from test');
}
function run() {
  return 5;
}
console.log(run());

Почему при работе в файле_1 вызывается дополнительно "run()", хотя должна вызываться только "test()"
  • Вопрос задан
  • 52 просмотра
Пригласить эксперта
Ответы на вопрос 1
delphinpro
@delphinpro
frontend developer
Потому что при импорте файлы выполняется.
В этом файле есть вызов функции run (в консоль лог)
Вот она и выполняется.

Если уберете console.log, то не будет выполняться.
вспоминается квантовая фигня: факт наблюдения меняет состояние =)
Ответ написан
Ваш ответ на вопрос

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

Похожие вопросы
27 нояб. 2024, в 18:19
2000 руб./за проект
27 нояб. 2024, в 17:41
2000 руб./за проект
27 нояб. 2024, в 17:26
1 руб./за проект