ts-loader, antd и typcript - не удается найти модуль index.less - PullRequest
0 голосов
/ 03 июля 2018

В моем проекте я использую antd реагирующая библиотека компонентов, и мне нужно использовать ts-loader для загрузки компонентов разумным способом. Сейчас я пытаюсь бороться с веб-пакетом для переноса меньше файлов, но получаю следующую ошибку:

ERROR in ./node_modules/antd/lib/button/style/index.less
Module build failed: Error: Cannot find module 'less'
    at Function.Module._resolveFilename (internal/modules/cjs/loader.js:594:15)
    at Function.Module._load (internal/modules/cjs/loader.js:520:25)
...

Похоже, что загрузчик less не установлен (он есть) или настроен неправильно (так и должно быть). Вот мой конфиг веб-пакета:

webpack.dev.js

module: {
    rules: [
      {
        test: /\.scss$/,
        loaders: ['style-loader', 'css-loader', 'postcss-loader', 'sass-loader']
      },
      {
        test: /\.css$/,
        loaders: ['style-loader', 'css-loader']
      },
      {
        test: /\.less$/,
        loader: 'less-loader' // compiles Less to CSS
      },
    ]
  },

common.webpack.js

const getTsLoaderRule = env => {
  const rules = [
    { loader: 'cache-loader' },
    {
      loader: 'ts-loader',
      options: {
            transpileOnly: true,
            getCustomTransformers: () => ({
            before: [ tsImportPluginFactory({
              libraryDirectory: 'es',
              libraryName: 'antd',
              style: 'css',
            })]
          }),
          compilerOptions: {
            module: 'es2015'
          }
        },
    }
  ];
  if (env === 'development') {
    rules.unshift({
      loader: 'react-hot-loader/webpack'
    });
  }
  return rules;
};
...
module: {
    rules: [
      {
        test: /\.tsx?$/,
        use: getTsLoaderRule(options.env),
        include: [utils.root('./src/main/webapp/app')],
        exclude: ['node_modules']
      },
      {
        test: /\.(jpe?g|png|gif|svg|woff2?|ttf|eot)$/i,
        loaders: ['file-loader?hash=sha512&digest=hex&name=content/[hash].[ext]']
      },
      {
        enforce: 'pre',
        test: /\.jsx?$/,
        loader: 'source-map-loader'
      },
      {
        test: /\.tsx?$/,
        enforce: 'pre',
        loaders: 'tslint-loader',
        exclude: ['node_modules']
      }
    ]
  },

Есть идеи?

1 Ответ

0 голосов
/ 04 июля 2018

Сообщение об ошибке не о неправильно сконфигурированном less-loader, а об отсутствующем less, который является зависимостью пакета от однорангового узла. Запустите npm i -S less, чтобы установить его.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...