gpt4 book ai didi

jQuery 未定义(使用 Webpack)

转载 作者:行者123 更新时间:2023-11-30 23:51:45 25 4
gpt4 key购买 nike

我有三个脚本:

<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 is not Defined 错误。

顺便说一句,在我的 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

PACKAJGE.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"
}
}

最佳答案

您需要使用expose-loader以便使 jQuery 可用于全局范围内的其他脚本。

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

关于jQuery 未定义(使用 Webpack),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47469228/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com