【发布时间】:2019-09-17 14:43:47
【问题描述】:
我正在尝试通过 Webpack 在 Rails 6.0.0.rc1 中安装 jQuery,但我不确定我缺少什么,但我在浏览器控制台中收到错误 $ is not defined,尽管能够编译 jQuery .
我添加了带有yarn add jquery 的jQuery,所以我的package.json 看起来像这样
{
"name": "muladeseis_app",
"private": true,
"dependencies": {
"@babel/preset-react": "^7.0.0",
"@rails/actioncable": "^6.0.0-alpha",
"@rails/activestorage": "^6.0.0-alpha",
"@rails/ujs": "^6.0.0-alpha",
"@rails/webpacker": "^4.0.2",
"babel-plugin-transform-react-remove-prop-types": "^0.4.24",
"jquery": "^3.4.0",
"prop-types": "^15.7.2",
"react": "^16.8.6",
"react-dom": "^16.8.6",
"turbolinks": "^5.2.0"
},
"version": "0.1.0",
"devDependencies": {
"webpack-dev-server": "^3.3.1"
}
}
我的 app/javascript/packs/application.js 需要来自 node_modules 的 jquery
require("@rails/ujs").start()
require("turbolinks").start()
require("@rails/activestorage").start()
require("channels")
require("jquery")
我尝试通过以下方式在 config/webpack/environment.js 中注册 $:
const { environment } = require('@rails/webpacker')
const webpack = require('webpack')
module.exports = environment
environment.plugins.append(
'Provide',
new webpack.ProvidePlugin({
$: 'jquery',
jQuery: 'jquery'
})
)
每当我在视图中添加带有$ 引用的脚本时,我都会得到Uncaught ReferenceError: $ is not defined。
我已经检查了 StackOverflow 的答案,例如 this,以查看我是否错误地注册了关键字符“$”,但我发现只有答案建议使用我已经在我的配置中提到的 ProvidePlugin。
另外,如果我在浏览器检查器中探索我的应用程序源,我确实看到 jQuery 代码集成在 localhost:3000 >> packs/js 中,所以问题不在于 Webpack 没有找到 jQuery,而是关键字 '$' 和 ' jQuery' 无法识别。
感谢您帮助调试此问题。
【问题讨论】:
标签: jquery ruby-on-rails webpack ruby-on-rails-6