谷歌地图错误 - 未捕获的ReferenceError:谷歌未定义 - 自耕农

Mat*_*kin 6 google-maps angularjs yeoman ionic-framework

在yeoman-ionic框架上我试图将谷歌地图添加到我的应用程序.问题是,每次我运行grunt服务index.html脚本被删除.所以我运行了这个:bower install --save angular-google-maps并解决了问题,因为除了index.html之外,它还在其他文件上编写了脚本.唯一的问题是,当我运行咕噜声服务时,我得到了一个不同的错误,从那以后我就无法弄清楚我做错了什么...

错误:

未捕获的ReferenceError:未定义谷歌

我认为它与某些业力配置文件有关,虽然我不知道这是什么.试图解决这个问题几个小时,无法解决这个问题......

rmg*_*n3t 11

我也得到了这个错误.事实证明这与我加载脚本文件的顺序有关.尝试按此顺序加载脚本文件:

<script src='//maps.googleapis.com/maps/api/js?sensor=false'></script>
<script src='/path/to/underscore[.min].js'></script>
<script src='/path/to/lodash.underscore[.min].js'></script>
<script src='/path/to/angular-google-maps[.min].js'></script>
Run Code Online (Sandbox Code Playgroud)

最好!


小智 6

您必须使用Google Maps SDK Async Loader.它保证在所有Google Maps SDK完全就绪之前,angular-google-maps不会开始处理任何指令.

配置:

    .config(function(uiGmapGoogleMapApiProvider) {
    uiGmapGoogleMapApiProvider.configure({
        //    key: 'your api key',
        v: '3.20', //defaults to latest 3.X anyhow
        libraries: 'weather,geometry,visualization'
    });
});
Run Code Online (Sandbox Code Playgroud)

Google Maps SDK何时准备就绪?:

    .controller("someController", function($scope, uiGmapGoogleMapApi) {
    uiGmapGoogleMapApi.then(function(maps) {
     // write your code here
     // (google is defined)
    });
});
Run Code Online (Sandbox Code Playgroud)

您也可以阅读http://angular-ui.github.io/angular-google-maps/#!/api/GoogleMapApi