如何将 Webpack 与 Google 地图 API 一起使用?
How to use Webpack with Google Maps API?
我正在使用 Webpack + html-webpack-plugin 来构建我所有的静态文件。问题是,当我将它与 Google 地图 API 一起使用时,它不起作用。
我有这个代码:
var map;
function initMap() {
map = new google.maps.Map(document.getElementById('map'), {
center: {lat: -34.397, lng: 150.644},
zoom: 6
});
// the other code, irrelevant
}
还有一个 HTML 文件:
<!doctype html>
<html>
<head>
</head>
<body>
<div id="map"></div>
<script async="async" defer="defer"
src="https://maps.googleapis.com/maps/api/js?key=<token here>&callback=initMap">
</script>
<script src="script.js"></script>
</body>
</html>
如果我 运行 只有这个文件,一切正常。但是如果我运行这个用,webpack它会抱怨'initMap is not a function'。我查看了输出内部,似乎 initMap 没有声明为全局函数,而是声明为模块内部的函数或类似的函数,所以这可能就是问题所在。
我应该如何将 Google 地图 API 与 webpack 一起使用?我知道我可以将一些库与我的脚本捆绑在一起,例如反应,我应该这样做吗?这里的方法应该是什么?
更新:这是我的 webpack.config.js:
/* eslint-disable */
const path = require('path')
const fs = require('fs')
const webpack = require('webpack')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const nodeModules = {}
fs.readdirSync('node_modules')
.filter(function(x) {
return ['.bin'].indexOf(x) === -1
})
.forEach(function(mod) {
nodeModules[mod] = 'commonjs ' + mod
})
const htmlMinifierObj = {
collapseWhitespace: true,
removeComments: true
}
module.exports = [
// the first object compiles backend, I didn't post it since it's unrelated
{
name: 'clientside, output to ./public',
entry: {
script: [path.join(__dirname, 'clientside', 'script.js')]
},
output: {
path: path.join(__dirname, 'public'),
filename: '[name].js'
},
module: {
loaders: [
{
test: /\.js$/,
loader: 'babel',
query: { presets:['es2015', 'stage-0'] }
}
],
},
plugins: [
//new webpack.optimize.UglifyJsPlugin({minimize: true}),
new HtmlWebpackPlugin({
template: 'clientside/index.html',
inject: 'body',
chunks: ['script'],
minify: htmlMinifierObj
})
],
}]
并且输出 HTML 是(我已经从我的源文件中删除了导入 script.js
,因为它是由 webpack 添加的,并关闭了最小化,只是为了便于阅读):
<!doctype html>
<html>
<head>
</head>
<body>
<a href="/login/facebook">Login</a>
<div id="map"></div>
<script async defer
src="https://maps.googleapis.com/maps/api/js?key=AIzaSyCGSgj5Ts10UdapzUnWlr34NS5cuoBj7Wg&callback=initMap">
</script>
<script type="text/javascript" src="script.js"></script></body>
</html>
在script.js
函数声明后,将函数添加到全局范围,如下所示:
function initMap() {
// Some stuff
}
window.initMap = initMap;
我正在使用 Webpack + html-webpack-plugin 来构建我所有的静态文件。问题是,当我将它与 Google 地图 API 一起使用时,它不起作用。
我有这个代码:
var map;
function initMap() {
map = new google.maps.Map(document.getElementById('map'), {
center: {lat: -34.397, lng: 150.644},
zoom: 6
});
// the other code, irrelevant
}
还有一个 HTML 文件:
<!doctype html>
<html>
<head>
</head>
<body>
<div id="map"></div>
<script async="async" defer="defer"
src="https://maps.googleapis.com/maps/api/js?key=<token here>&callback=initMap">
</script>
<script src="script.js"></script>
</body>
</html>
如果我 运行 只有这个文件,一切正常。但是如果我运行这个用,webpack它会抱怨'initMap is not a function'。我查看了输出内部,似乎 initMap 没有声明为全局函数,而是声明为模块内部的函数或类似的函数,所以这可能就是问题所在。
我应该如何将 Google 地图 API 与 webpack 一起使用?我知道我可以将一些库与我的脚本捆绑在一起,例如反应,我应该这样做吗?这里的方法应该是什么?
更新:这是我的 webpack.config.js:
/* eslint-disable */
const path = require('path')
const fs = require('fs')
const webpack = require('webpack')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const nodeModules = {}
fs.readdirSync('node_modules')
.filter(function(x) {
return ['.bin'].indexOf(x) === -1
})
.forEach(function(mod) {
nodeModules[mod] = 'commonjs ' + mod
})
const htmlMinifierObj = {
collapseWhitespace: true,
removeComments: true
}
module.exports = [
// the first object compiles backend, I didn't post it since it's unrelated
{
name: 'clientside, output to ./public',
entry: {
script: [path.join(__dirname, 'clientside', 'script.js')]
},
output: {
path: path.join(__dirname, 'public'),
filename: '[name].js'
},
module: {
loaders: [
{
test: /\.js$/,
loader: 'babel',
query: { presets:['es2015', 'stage-0'] }
}
],
},
plugins: [
//new webpack.optimize.UglifyJsPlugin({minimize: true}),
new HtmlWebpackPlugin({
template: 'clientside/index.html',
inject: 'body',
chunks: ['script'],
minify: htmlMinifierObj
})
],
}]
并且输出 HTML 是(我已经从我的源文件中删除了导入 script.js
,因为它是由 webpack 添加的,并关闭了最小化,只是为了便于阅读):
<!doctype html>
<html>
<head>
</head>
<body>
<a href="/login/facebook">Login</a>
<div id="map"></div>
<script async defer
src="https://maps.googleapis.com/maps/api/js?key=AIzaSyCGSgj5Ts10UdapzUnWlr34NS5cuoBj7Wg&callback=initMap">
</script>
<script type="text/javascript" src="script.js"></script></body>
</html>
在script.js
函数声明后,将函数添加到全局范围,如下所示:
function initMap() {
// Some stuff
}
window.initMap = initMap;