Как использовать динамический c импорт в машинописи с приложением webpack - PullRequest
0 голосов
/ 04 февраля 2020

Я импортировал некоторые из своих модулей динамически на основе нажатия кнопки, я использовал, как показано ниже "

import { Button } from '@syncfusion/ej2-buttons';

// Initialize Button component.
let button: Button = new Button({ content: 'Button' });

// Render initialized Button.
button.appendTo('#element');

document.getElementById('element').addEventListener("click", function(){
  check();
});

async function check() {
import("@syncfusion/ej2-grids").then((Grid) => {
  debugger
  console.log(Grid);
});
}

мой файл конфигурации webpack:

const path = require("path");
const UglifyJsPlugin = require("uglifyjs-webpack-plugin");

module.exports = {
  mode: "development",
  entry: {
    "src/app/bundle": "./src/app/index.ts"
  },
  output: {
    publicPath: "/js/",
    filename: "src/app/bundle.js"
  },
  devtool: "none",
  module: {
    rules: [
      {
        loader: "ts-loader",
        exclude: /node_modules/
      }
    ]
  },

  resolve: {
    extensions: [".ts", ".js"]
  }
};

когда я компилирую и запускаю свое приложение, оно выдает ошибку ниже

Каково текущее поведение?

Выдает ошибку ниже error message

Если текущее поведение является ошибкой, пожалуйста, укажите шаги для воспроизведения.

clone sample - https://github.com/kumaresan-subramani/dynamic-import/blob/master/webpack.config.js
run npm i
gulp compile
gulp start

Затем нажмите кнопку в браузере, вы увидите см. сообщение об ошибке в моей консоли.

Какое поведение ожидается?

Модуль Dynami c должен загружаться правильно

Прочие соответствующие информация:

"typescript": "3.7.5",
"uglifyjs-webpack-plugin": "^2.0.1",
"webpack": "^4.29.6",
"webpack-cli": "*",
"webpack-stream": "^5.2.1"
Node.js version: 10.15.1
Operating System: windows 10

1 Ответ

0 голосов
/ 07 февраля 2020

Вся логика c кажется мне странной. Если вы используете модуль, просто импортируйте его, а затем используйте его при определенных условиях или после запуска события

...