I’m working on a Custom Control that displays markers on Google Maps. I have a couple of properties like “maptype” , “zoom”, etc. It is easy to access them in Javascript: I can use #{javascript:compositeData.zoom} to get the value of the zoom property.
Now this is my problem: I use a group of properties for each marker.
The name of the group is “marker” and a marker has 6 properties: “title”, “layer”, “infotext”, “icon”, “address” and “animation”.
If I try to access the group with
var markers = #{javascript:compositeData.marker};
I’m getting an error in firebug:
missing : after property id var markers = [{layer=2,
address=Oldenzaal, animation=DROP, icon=/ogo_notes.png…
an arrow is pointing to the first = between layer and 2
(I am not allowed to put in an image in stackoverflow)
If I use
var markers = #{javascript:'"' + compositeData.marker + '"'};
markers is an Object, but each Object contains a string with all the propperties of the marker.
I know I can do some coding to make an object of each string, but this is not easy if not all propperties are required. If a propperty is not required than it will not show up in the string.
I guess that there must be a more easy way to get each marker as an object so I can get the value of the icon with code like:
var icon = marker.icon
How can I do this?
You can use
compositeData.marker.iconto get the propertyiconinside the groupmarker. If you have checked “Allow multiple instances” for the group then to get the properties you will have to go:and so on…
Update 26-Apr-2012 (Naveen)
To use it with client side javascript you can try to put the value in a hidden input field like this:
The value of this hidden input field can be read through client-side javascript like this:
Another way to do this can be to convert
compositeData.markerand its contents to a JSON string and then run the client-side javascript on it.