Reputation: 1362
I'm fetching an array and I would like to insert some of the data into two places in javascript but I don't know how to do it correctly, can someone please help me?
I'm fetching an array in PHP/MYSQL like so:
<?php while($row = mysql_fetch_array( $result )) { ?>
<?php
//I WANT TO LOOP THE BELOW CODE IN JAVASCRIPT SOMETHING LIKE THIS?:
echo 'var point'.$count.'= new google.maps.LatLng('.$LAT.', '.$LNG.');';
?>
<?php
// I WANT TO LOOP THIS ALSO BUT IT IS AT THE END OF THE JAVASCRIPT CODE AND THERE IS CODE IN THE MIDDLE THAT I DON'T WANT LOOPED
echo 'var marker'.$count.'= new google.maps.Marker({draggable: true,raiseOnDrag: false,icon: image,shadow: shadow,shape: shape,map: map,position: point'.$count.'});';
?>
<?php } ?>
The JavaScript looks like this:
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
<script type="text/javascript">
function load(){
//** START LOOP THIS IN PHP **//
var point1 = new google.maps.LatLng(44.8041322, -93.1668858); //LOOP THIS IN PHP
//** END LOOP THIS IN PHP **//
var myMapOptions = {
zoom: 5,
center: point,
mapTypeId: google.maps.MapTypeId.TERRAIN
};
var map = new google.maps.Map(document.getElementById("map"),myMapOptions);
var image = new google.maps.MarkerImage(
'marker-images/image.png',
new google.maps.Size(40,35),
new google.maps.Point(0,0),
new google.maps.Point(20,35)
);
var shadow = new google.maps.MarkerImage(
'marker-images/shadow.png',
new google.maps.Size(62,35),
new google.maps.Point(0,0),
new google.maps.Point(20,35)
);
var shape = {
coord: [27,0,30,1,32,2,34,3,35,4,36,5,38,6,39,7,39,8,39,9,39,10,38,11,37,12,33,13,34,14,34,15,33,16,32,17,31,18,27,19,28,20,28,21,27,22,26,23,22,25,23,26,24,27,24,28,24,29,24,30,24,31,24,32,23,33,22,34,17,34,16,33,15,32,15,31,14,30,14,29,15,28,15,27,16,26,17,25,13,23,12,22,11,21,11,20,12,19,8,18,7,17,6,16,5,15,5,14,6,13,2,12,1,11,0,10,0,9,0,8,0,7,1,6,3,5,4,4,5,3,7,2,9,1,12,0,27,0],
type: 'poly'
};
//** START LOOP THIS IN PHP **//
var marker1 = new google.maps.Marker({draggable: true,raiseOnDrag: false,icon: image,shadow: shadow,shape: shape,map: map,position: point1});
//** END LOOP THIS IN PHP **//
}
</script>
I just don't know how to loop the info two times, the var point1... loop that is on top is not really a problem but how do i loop the bottom part without looping all of the javascript
Upvotes: 1
Views: 390
Reputation: 2418
The below should work, then simply insert $point_str and $marker_str in the appropriate places after the while loop.
<?php
$point_str = '';
$marker_str = '';
while($row = mysql_fetch_array( $result )) {
// define $LAT, $LNG, $count++
$point_str .= 'var point'.$count.'= new google.maps.LatLng('.$LAT.', '.$LNG.');'."\n";
$marker_str .= 'var marker'.$count.'= new google.maps.Marker({draggable: true,raiseOnDrag: false,icon: image,shadow: shadow,shape: shape,map: map,position: point'.$count.'});'."\n";
}
?>
Upvotes: 1