问题是当我将数据控制器传递给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
循环,则标记即将出现,但没有标签...
有人知道我在这里想念什么吗?
答案 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)
});
}
}