jQuery未定义(使用Webpack)

11

我有三个脚本:

<script type="text/javascript" src="main.min.js"></script>
<script type="text/javascript" src="script-A.js"></script>
<script type="text/javascript" src="script-B.js"></script>

main.min.js是我使用Webpack创建的文件。这个文件包含了我项目中需要的所有脚本,包括jQuery,我已经将它安装为NPM包。

script-A.jsscript-B.js是我不能将它们包含在我的主Webpack文件中的脚本,所以我需要单独加载它们。这些脚本需要jQuery作为依赖项;尽管jQuery已经包含在main.min.js中,但当它们被调用时,我会得到一个“jQuery未定义”的错误。

顺便说一下,在我的Webpack文件中,我已经有了这些代码行,让我可以在通过Webpack处理的任何脚本中使用jQuery,但它似乎对其他脚本没有任何影响:

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

如何修复这个错误?理想情况下,我需要一个解决方案,不用修改 script-A.jsscript-B.js ,因为它们属于插件。

控制台片段

Uncaught ReferenceError: jQuery is not defined
    at script-A.js?ver=2.9.6:1
Uncaught ReferenceError: jQuery is not defined
    at script-B.js:617
    at script-B.js:620

包(package).json

{
  "name": "mysite",
  "version": "1.0.0",
  "description": "mysite",
  "main": "webpack.config.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "jquery": "^3.2.1",
    "jquery-lazy": "^1.7.5",
    "salvattore": "^1.0.9",
    "webpack": "^3.6.0"
  },
  "devDependencies": {
    "babel-core": "^6.26.0",
    "babel-loader": "^7.1.2",
    "babel-preset-es2015": "^6.24.1",
    "browser-sync": "^2.18.13",
    "browser-sync-webpack-plugin": "^1.2.0",
    "css-loader": "^0.28.7",
    "extract-text-webpack-plugin": "^3.0.1",
    "file-loader": "^1.1.5",
    "node-sass": "^4.5.3",
    "sass-loader": "^6.0.6",
    "style-loader": "^0.19.0",
    "url-loader": "^0.6.2",
    "webpack-merge": "^4.1.0"
  }
}

你能展示一下控制台片段吗? - Pravesh Khatri
你能分享一下你的 package.json 文件吗? - Pravesh Khatri
@PraveshKhatri 我更新了我的答案,感谢您的查阅。 - grazdev
如果您没有使用Angular,可以删除"window.jQuery": 'jquery',请尝试。 - Pravesh Khatri
我认为没有办法在外部脚本中使用来自webpack捆绑包的插件。也许从你的webpack配置中删除jquery,然后在你的.html文件中手动包含jquery会有所帮助? - Rick
显示剩余2条评论
1个回答

23

为了让jQuery在全局范围内对其他脚本可用,您需要使用expose-loader

module: {
  rules: [{
    test: require.resolve('jquery'),
    use: [{
        loader: 'expose-loader',
        options: 'jQuery'
    },{
        loader: 'expose-loader',
        options: '$'
    }]
  }]
}

是的!完美!非常感谢你! - grazdev

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接