使用Webpack 4时如何访问条目文件中的jQuery对象($)?

问题描述 投票:0回答:1

我有一个非常简单的Webpack 4示例,我试图访问我的条目文件中的jQuery对象,以便操作DOM。我已经把它减少到了我认为已经广泛研究的最低限度。

我希望该示例在页面加载时将body的背景颜色设置为青色。似乎无法做任何事情。看起来在条目文件中公开的$变量与浏览器中的$变量不同。

更新 - 问题已解决:我在下面滥用jQuery

原始(有缺陷的)条目文件(src/app.js):

import 'jquery';

$(() => {
  $('body').bgColor = 'cyan';
});

更正的条目文件:

import 'jquery';

$(() => {
  $('body').css('background-color', 'cyan');
});

我使用ProvidePlugin作为记录的here。这是我简单的webpack.config.js文件:

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const webpack = require("webpack");

module.exports = {
  entry: {
    app: './src/app.js',
  },
    output: {
      filename: 'bundle.js',
        path: path.resolve(__dirname, 'dist')
    },
    plugins: [
      new webpack.ProvidePlugin({
        $: 'jquery',
        jQuery: 'jquery'
      }),
      new HtmlWebpackPlugin()
    ],
    devtool: 'inline-source-map'
}

Webpack编译得很好,页面打开(使用webpack-dev-server),但背景颜色不会像预期的那样变为青色。当我在$('body')文件中记录app.js的值时,我得到undefined

这是package.json文件:

{
  "name": "foo",
  "version": "1.0.0",
  "description": "",
  "private": true,
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "build": "webpack",
    "start": "webpack-dev-server --inline --open"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "html-webpack-plugin": "^3.2.0",
    "webpack": "^4.16.5",
    "webpack-cli": "^3.1.0",
    "webpack-dev-server": "^3.1.5"
  },
  "dependencies": {
    "jquery": "^3.3.1"
  }
}

感觉就像我基本上不了解它应该如何工作。谢谢。非常感谢您的帮助。

jquery webpack-4
1个回答
0
投票

道歉。我误用了jQuery的错误。感谢@charlietfl指出我在评论中的错误。我用了。 $('body').bgColor = "cyan"而不是$('body').css('background-color', 'cyan')。其他一切都已正确配置。所以如果你需要一个简单的例子,那就是。

我将编辑问题并指出我的错误。

© www.soinside.com 2019 - 2024. All rights reserved.