Javascript 谷歌地图v3上的信息窗口不';行不通

Javascript 谷歌地图v3上的信息窗口不';行不通,javascript,json,google-maps-api-3,google-maps-markers,infowindow,Javascript,Json,Google Maps Api 3,Google Maps Markers,Infowindow,对不起,我的英语不好 我有个小问题。 我从外部json文件加载json数据。 此处显示文件的内容: { "Pizza Dach": { "Kategorie": "Pizza", "Position": { "Longitude": 13.456106, "Latitude": 52.51024 } }, "Burgeramt": { "Kategorie": "Burger", "Position": {

对不起,我的英语不好 我有个小问题。 我从外部json文件加载json数据。 此处显示文件的内容:

{
"Pizza Dach": {
    "Kategorie": "Pizza",
    "Position": {
        "Longitude": 13.456106,
        "Latitude": 52.51024
    }
},
"Burgeramt": {
    "Kategorie": "Burger",
    "Position": {
        "Longitude": 13.459539,
        "Latitude": 52.510299
    }
},
"DUDU": {
    "Kategorie": "Pizza",
    "Position": {
        "Longitude": 13.415165,
        "Latitude": 52.493024
    }
}
}
这是我的js代码:

var karte;
var marker;
var meineLongitude, meineLatitude;

/* Karte */

var positionsAusgabe = function(position){
    width = document.getElementById('karte').offsetWidth;
    height = document.getElementById('karte').offsetHeight;

    meineLongitude = position.coords.longitude;
    meineLatitude = position.coords.latitude;

    var optionen = {
        zoom: 13,
        center: new google.maps.LatLng(meineLatitude, meineLongitude),
        mapTypeId: google.maps.MapTypeId.ROADMAP
    };

var infoWindow = new google.maps.InfoWindow();


    karte = new google.maps.Map(document.getElementById('karte'), optionen);

    window.setTimeout(function(){

        $.getJSON('daten/restaurants.json?='+Date.now(), function(data){
            $.each(data, function(restaurant, daten){

marker = new google.maps.Marker({
                    map: karte,
                    icon: 'bilder/'+daten.Kategorie+'.png',

                    position: new google.maps.LatLng(daten.Position.Latitude,daten.Position.Longitude)
                });

(function(marker, data) {
                google.maps.event.addListener(marker, "click", function(e) {
                    infoWindow.setContent('+daten.Kategorie+');
                    infoWindow.open(map, marker);
                });

      });


            });

        //  window.scrollTo(0,1);

        });

    },1); 

};
问题是,标记正在设置,具有正确的图标和位置,但我不知道为什么信息窗口不出现。我确信我在js代码中犯了一些错误,但是我没有发现错误。 有人有主意吗?
非常感谢。:-)

这部分代码将不起任何作用:

  (function(marker, data) {
            google.maps.event.addListener(marker, "click", function(e) {
                infoWindow.setContent('+data.Kategorie+');
                infoWindow.open(map, marker);
            });

  });
您定义了一个函数,但没有执行它

试试这个:

  (function(marker, data) {
            google.maps.event.addListener(marker, "click", function(e) {
                infoWindow.setContent(daten.Kategorie);
                infoWindow.open(karte, marker);
            });

  }(marker,daten));
但是,不需要此功能。您已经在函数(每个$回调)中,当您将标记变量设置为本地时,它不会被覆盖:

        $.each(data, function(restaurant, daten){

            var marker = new google.maps.Marker({
                map: karte,
                icon: 'bilder/'+daten.Kategorie+'.png',
                position: new google.maps.LatLng(daten.Position.Latitude,daten.Position.Longitude)
            });

            google.maps.event.addListener(marker, "click", function(e) {
                infoWindow.setContent(daten.Kategorie);
                infoWindow.open(karte, marker);
            });

        });

发布的代码包含javascript错误。您可以通过jslint运行它,或者将它放在一个显示问题的小提琴中。@geocodezip:我没有看到代码中有错误(至少没有语法错误会停止执行)