我正在使用 Rails 6.0.0.rc1 并希望实现Google-Maps-for-Rails gem。我通过Yarn安装了下划线,并在我的标签中使用我的 API 添加了所需的谷歌脚本。
我下载gmaps_google.js
并将其添加到我的 vendor/js 文件夹中,因为 Rails 6 没有资产管道,而是使用 webpacker。这是我认为问题所在,因为我收到以下错误:
ReferenceError: Can't find variable: Gmaps
我更新了我的webpacker.yml
文件以查找 vendor/js 文件夹,并且在检查 DOM 时它似乎存在。
webpacker.yml
# Additional paths webpack should lookup modules
# ['app/assets', 'engine/foo/app/assets']
resolved_paths: ['vendor/js']
在我的javascript/packs/application.js
我包括了一条require("gmaps_google")
线。请注意,我在使用 Highcharts 时遇到了同样的问题,但能够成功加载脚本但添加window.Highcharts = Highcharts;
但我不确定我是否可以使用 require 选项做同样的事情?
javascript/packs/application.js
require("@rails/ujs").start()
require("turbolinks").start()
require("@rails/activestorage").start()
require("channels")
require('jquery')
require("trix")
require("@rails/actiontext")
window.Highcharts = Highcharts;
import Highcharts from 'highcharts';
import addMore from "highcharts/highcharts-more";
import 'bootstrap'
import 'underscore'
require("gmaps_google")
包.json
{
"name": "app_name",
"private": true,
"dependencies": {
"@rails/actioncable": "^6.0.0-alpha",
"@rails/actiontext": "^6.0.0-rc1",
"@rails/activestorage": "^6.0.0-alpha",
"@rails/ujs": "^6.0.0-alpha",
"@rails/webpacker": "^4.0.7",
"bootstrap": "^4.3.1",
"highcharts": "^7.1.2",
"jquery": "^3.4.1",
"popper.js": "^1.15.0",
"trix": "^1.0.0",
"turbolinks": "^5.2.0",
"underscore": "^1.9.1"
},
"version": "0.1.0",
"devDependencies": {
"webpack-dev-server": "^3.7.1"
}