Webpack jQuery и jQuery.lazy () Ошибка типа: q не определено - PullRequest
0 голосов
/ 20 февраля 2019

как я могу связать jquery и jquery.lazy с веб-пакетом?- Каждый раз, когда я пытаюсь это сделать, я получаю сообщение об ошибке.

Моя ошибка заключается в следующем в консоли отладки моего браузера:

TypeError: q is undefined

Остальное работает нормально.Может быть, вы видите, что я сделал что-то не так.

Мой package.json:

{
      "name": "mrd-apple",
      "version": "1i.0.0",
      "description": "mrd Apple",
      "main": "webpack.config.js",
      "scripts": {
        "test": "echo \"Error: no test specified\" && exit 1"
      },
      "author": "",
      "license": "ISC",
      "dependencies": {
        "jquery": "^3.3.1",
        "jquery-lazy": "^1.7.10",
        "postcss-loader": "^3.0.0",
        "webpack": "^4.29.3"
      },
      "devDependencies": {
        "css-loader": "^2.1.0",
        "style-loader": "^0.23.1",
        "webpack-cli": "^3.2.3"
      }
    }
}

Мой webpack.config.js

var webpack = require('webpack');
const UglifyJsPlugin = require("uglifyjs-webpack-plugin");
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
var OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin');

module.exports = function(env) {
    return {
        entry: ['./src/js/index.js'],
        output: {
            path: __dirname + '/dist',
            filename: 'bundle.js'
        },
        plugins: [
            new webpack.ProvidePlugin({
                $: 'jquery',
                jQuery: 'jquery'
            }),
            new MiniCssExtractPlugin({
                // Options similar to the same options in webpackOptions.output
                // both options are optional
                filename: "[name].css",
                chunkFilename: "[id].css"
            }),
            new OptimizeCSSAssetsPlugin({
                assetNameRegExp: /\.optimize\.css$/g,
                cssProcessor: require('cssnano'),
                cssProcessorPluginOptions: {
                    preset: ['default', { discardComments: { removeAll: true } }],
                },
                canPrint: true
            })
        ],
        module: {
            rules: [
                {
                    test: /\.css$/,
                    use: [
                        {
                            loader: MiniCssExtractPlugin.loader,
                            options: {
                                // you can specify a publicPath here
                                // by default it use publicPath in webpackOptions.output
                                publicPath: '../'
                            }
                        },
                        "css-loader"
                    ]
                }
            ]
        },
        optimization: {
            minimizer: [
                new UglifyJsPlugin({
                    cache: true,
                    parallel: true,
                    sourceMap: true // set to true if you want JS source maps
                }),
                new OptimizeCSSAssetsPlugin({})
            ]
        },
    }
}

Содержание индекса.js

// JS 
// require('./jquery.lazy'); 
require('./lightslider'); 
require('./simple-lightbox'); 
require('./init'); 

// CSS 
require('./../css/index.css');

1 Ответ

0 голосов
/ 01 марта 2019

Ваша проблема в том, как вы пытаетесь использовать require.js

Прежде всего, есть проблемы с вашим package.json:

  • и webpack, и postcss-loader - это devDependencies.
  • Также ваша версия недействительна.
  • Мне пришлось добавить следующее как devDependencies: uglifyjs-webpack-plugin, mini-css-extract-plugin, optimize-css-assets-webpack-plugin

Однако проблема заключается в том, как вы пытаетесь включить эти библиотеки.

При использовании require.js с package.json и веб-пакетом вы не будете пытаться запрашивать сам файл .js, вместо этого вы либо require('npm-package-name'), либо, что еще лучше, import NpmPackageName from 'npm-package-name';См .: Управление зависимостями

Если вы хотите загрузить библиотеку с помощью HTML на своей странице и вместо этого просто ссылаться на нее в своем источнике, вы можете сделать это с помощью внешних веб-пакетов.См. Webpack Externals

для справки. Вот мои версии ваших файлов:

package.json:

{
  "name": "mrd-apple",
  "version": "1.0.0",
  "description": "mrd Apple",
  "main": "webpack.config.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "jquery": "^3.3.1",
    "jquery-lazy": "^1.7.10"
  },
  "devDependencies": {
    "css-loader": "^2.1.0",
    "mini-css-extract-plugin": "^0.5.0",
    "optimize-css-assets-webpack-plugin": "^5.0.1",
    "postcss-loader": "^3.0.0",
    "style-loader": "^0.23.1",
    "uglifyjs-webpack-plugin": "^2.1.2",
    "webpack": "^4.29.3",
    "webpack-cli": "^3.2.3"
  }
}

index.js:


// require('jquery');
// require('jquery-lazy');

import $ from 'jquery';
import jqueryLazy from 'jquery-lazy';


ПРИМЕЧАНИЕ. Мне не удалось выдать именно ту ошибку, которую вы указали, но предположите, что это связано с самой настройкой проекта.

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