Управление зависимостью плагина jQuery в webpack

Я использую Webpack в своем приложении, в котором я создаю две точки входа - bundle.js для всех моих файлов/кодов JavaScript и поставщиков.js для всех библиотек, таких как jQuery и React. Что мне делать, чтобы использовать плагины, которые имеют jQuery в качестве своих зависимостей, и я хочу иметь их также в поставщиках.Яш? Что делать, если эти плагины имеют несколько зависимостей?

В настоящее время я пытаюсь использовать этот плагин jQuery здесь -https://github.com/mbklein/jquery-elastic. В В документации Webpack упоминается providePlugin импорт-погрузчик. Я использовал providePlugin, но объект jQuery по-прежнему недоступен. Вот как мой webpack.конфиг.js выглядит как -

var webpack = require('webpack');
var bower_dir = __dirname + '/bower_components';
var node_dir = __dirname + '/node_modules';
var lib_dir = __dirname + '/public/js/libs';

var config = {
    addVendor: function (name, path) {
        this.resolve.alias[name] = path;
        this.module.noParse.push(new RegExp(path));
    },
    plugins: [
        new webpack.ProvidePlugin({
            $: "jquery",
            jquery: "jQuery",
            "window.jQuery": "jquery"
        }),
        new webpack.optimize.CommonsChunkPlugin('vendors', 'vendors.js', Infinity)
    ],
    entry: {
        app: ['./public/js/main.js'],
        vendors: ['react','jquery']
    },
    resolve: {
        alias: {
            'jquery': node_dir + '/jquery/dist/jquery.js',
            'jquery.elastic': lib_dir + '/jquery.elastic.source.js'
        }
    },
    output: {
        path: './public/js',
        filename: 'bundle.js'
    },
    module: {
        loaders: [
            { test: /.js$/, loader: 'jsx-loader' },
            { test: /.jquery.elastic.js$/, loader: 'imports-loader' }
        ]
    }
};
config.addVendor('react', bower_dir + '/react/react.min.js');
config.addVendor('jquery', node_dir + '/jquery/dist/jquery.js');
config.addVendor('jquery.elastic', lib_dir +'/jquery.elastic.source.js');

module.exports = config;

но, несмотря на это, все равно выдает ошибку в консоли браузера:

Uncaught ReferenceError: jQuery не определен

аналогично, когда я использую imports-loader, он выдает ошибку,

требуют не определено'

в этой строке:

var jQuery = require("jquery")

однако я мог бы использовать тот же плагин, когда я не добавляю его своим поставщикам.JS-файл и вместо этого требовал его обычным способом AMD, как я включаю свои другие файлы кода JavaScript, например -

define(
[
    'jquery',
    'react',
    '../../common-functions',
    '../../libs/jquery.elastic.source'
],function($,React,commonFunctions){
    $("#myInput").elastic() //It works

});

но это не то, что я хочу сделать, так как это означало бы, что jQuery.упругий.источник.js поставляется вместе с моим кодом JavaScript в комплекте.js, и я хочу, чтобы все мои Плагины jQuery были в поставщиках.JS расслоения. Так как должен ли я добиваться этого?

11 ответов


вы смешали различные подходы, как включить устаревшие модули поставщика. Вот как я бы с этим справился:--33-->

1. Предпочитайте unminified CommonJS / AMD над dist

большинство модулей ссылке dist версия


для глобального доступа к jquery существует несколько вариантов. В моем последнем проекте webpack я хотел глобальный доступ к jquery, поэтому я добавил следующее к моим объявлениям плагинов:

 plugins: [
    new webpack.ProvidePlugin({
      $: "jquery",
      jQuery: "jquery"
    })
  ]

это означает, что jquery доступен из исходного кода JavaScript через глобальные ссылки $ и jQuery.

конечно, вам также нужно установить jquery через npm:

$ npm i jquery --save

для рабочего примера этого подхода, пожалуйста, не стесняйтесь вилку мое приложение на github


Я не знаю, хорошо ли я понимаю, что вы пытаетесь сделать, но мне пришлось использовать плагины jQuery, которые требовали, чтобы jQuery был в глобальном контексте (окно), и я поместил следующее в мой entry.js:

var $ = require('jquery');
window.jQuery = $;
window.$ = $;

Я просто должен требовать, где я хочу jqueryplugin.min.js и window.$ расширен плагином, как и ожидалось.


добавьте это в массив плагинов в webpack.конфиг.js

new webpack.ProvidePlugin({
    'window.jQuery': 'jquery',
    'window.$': 'jquery',
})

тогда требовать jQuery нормально

require('jquery');

Если боль сохраняется, получая другие скрипты, чтобы увидеть его, попробуйте явно поместить его в глобальный контекст через (в записи js)

window.$ = jQuery;

у меня все работает хорошо, выставляя $ и jQuery как глобальные переменные с Webpack 3.8.1 и следующие.

установить jQuery как зависимость проекта. Вы можете опустить @3.2.1 установить последнюю версию или указать другую версию.

npm install --save jquery@3.2.1

установить expose-loader как зависимость от разработки, если она еще не установлена.

npm install expose-loader --save-dev

настройте Webpack для загрузки и предоставления jQuery для нас.

// webpack.config.js
const webpack = require('webpack')

module.exports = {
  entry: [
    // entry bits
  ],
  output: {
    // output bits
  },
  module: {
    rules: [
      // any other rules
      {
        // Exposes jQuery for use outside Webpack build
        test: require.resolve('jquery'),
        use: [{
          loader: 'expose-loader',
          options: 'jQuery'
        },{
          loader: 'expose-loader',
          options: '$'
        }]
      }
    ]
  },
  plugins: [
    // Provides jQuery for other JS bundled with Webpack
    new webpack.ProvidePlugin({
      $: 'jquery',
      jQuery: 'jquery'
    })
  ]
}

это работает в webpack 3:

в webpack.конфиг.вавилонское столпотворение.файл js:

resolve: {
    alias: {
         jquery: "jquery/src/jquery"
    },
 ....
}

и использовать ProvidePlugin

new webpack.ProvidePlugin({
        '$': 'jquery',
        'jQuery': 'jquery',
    })

Я пробовал некоторые из предоставленных ответов, но ни один из них не сработала. Тогда я попробовал это:

new webpack.ProvidePlugin({
    'window.jQuery'    : 'jquery',
    'window.$'         : 'jquery',
    'jQuery'           : 'jquery',
    '$'                : 'jquery'
});

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


лучшее решение, которое я нашел, было:

https://github.com/angular/angular-cli/issues/5139#issuecomment-283634059

в основном, вам нужно включить фиктивную переменную на типизациях.d.ts, удалите все "import * as $ from 'jquery" из вашего кода, а затем вручную добавьте тег в скрипт jQuery в свой SPA html. Таким образом, webpack не будет вам мешать, и вы сможете получить доступ к одной и той же глобальной переменной jQuery во всех ваших сценариях.


это работает для меня на webpack.конфиг.js

    new webpack.ProvidePlugin({
        $: 'jquery',
        jQuery: 'jquery',
        'window.jQuery': 'jquery'
    }),

в другом javascript или в HTML добавить:

global.jQuery = require('jquery');

Edit: иногда вы хотите использовать webpack просто как модульный пакет для простого веб-проекта - чтобы сохранить свой собственный код. Следующее решение для тех, кто просто хочет, чтобы внешняя библиотека работала, как ожидалось, внутри своих модулей - без использования много времени погружения в настройки webpack. (Отредактировано после -1)

быстрое и простое решение (es6), если вы все еще боретесь или хотите избежать внешних конфигураций / дополнительного плагина webpack config:

<script src="cdn/jquery.js"></script>
<script src="cdn/underscore.js"></script>
<script src="etc.js"></script>
<script src="bundle.js"></script>

внутри модуля:

const { jQuery: $, Underscore: _, etc } = window;

в webpack.конфиг.файл JS добавить ниже:

 var webpack = require("webpack");
 plugins: [
    new webpack.ProvidePlugin({
        $: "jquery",
        jQuery: "jquery"
    })
 ],

установить jQuery с помощью npm:

$ npm i jquery --save

в приложение.файл JS добавить ниже строки:

import $ from 'jquery';
window.jQuery = $;
window.$ = $;

это работает для меня. :)