Google Map,在Laravel / JS中的标记标签上显示数据

时间:2018-12-26 03:43:28

标签: javascript php laravel google-maps

问题是当我将数据控制器传递给Blade / JS时,首先我将其转换为JSON(因为没有其他方法),然后将其传递给da javascript。但是我的标签工作不正常。脚本代码在下面。

var estates = <?php echo json_encode($estates);?>

            function initMap()
            {
                var options =
                    {
                        zoom : 10,
                        center : {lat:34.652500, lng:135.506302}
                    };

                var map = new google.maps.Map(document.getElementById('map'), options);
                for (var i=0; i < estates.length; i++) {
                @foreach ($estates as $est)
                    var marker = new google.maps.Marker({
                            map: map,
                            label: estates.price,
                            position: {
                                lat: {{$est->lat}},
                                lng: {{$est->lng}}
                            }
                     });
                @endforeach
                }
            }

因此,如果我尝试像这样{{$est->price}}传递价格,则会出现语法令牌错误。由于价格是varchar,带有日语字符。因此,我需要先将其转换为Json并对其进行处理。但是,当我这样做时,地图上没有标记和标签。只是空的地图,控制台中也没有错误吗?如果我删除JS for循环,则标记即将出现,但没有标签...

有人知道我在这里想念什么吗?

1 个答案:

答案 0 :(得分:1)

尝试使用新的google.maps.LatLng()函数:

        var estates = <?php echo json_encode($estates);?>
        //estates = <?php echo json_decode($estates);?>
        function initMap()
        {
            var options =
                {
                    zoom : 10,
                    center : {lat:34.652500, lng:135.506302}
                }

            var map = new google.maps.Map(document.getElementById('map'), options);

            for (var i=0;i<estates.length;i++){
            var latLng_ = new google.maps.LatLng(estates['lat'],estates['lng']);
            var marker = new google.maps.Marker({
                    map: map,
                    position: latLng_,
                    icon: 'https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcRAy10Br9W1wWCSQNPc6f9CarvNEO4qqCg1BDbe7_mYZqHwXj3v',
                    label: estates['price']
                });


            var infoWindow = new google.maps.InfoWindow({
                content: estates['price']
            });

            marker.addListener('click', function () {
                infoWindow.open(map, marker)
            });
           }
        }