XQuery:在javascript函数中使用XQuery数据?

时间:2013-01-09 14:29:51

标签: javascript maps xquery

我的问题如下。我在xquery文件的顶部声明了一个包含一些位置的序列:

xquery version "1.0";
declare option exist:serialize "method=xhtml media-type=text/html";
let $locations := //location
return

然后我的<head>中有一个javascript代码,可以使用Google Maps API显示地图。我想知道的是如何在我的javascript函数中使用我的xquery变量$locations来在我的地图上显示标记?

我使用了来自http://google-maps-utility-library-v3.googlecode.com/svn/trunk/markerclusterer/examples/simple_example.html的代码:

<script type="text/javascript">
<!--
function initialize() {
    var center = new google.maps.LatLng(43.700,7.267);

    var map = new google.maps.Map(document.getElementById('map'), {
      zoom:12,
      center: center,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });

    var markers = [];
    for (var i = 0; i < 100; i++) {
      var dataPhoto = data.photos[i];
      var latLng = new google.maps.LatLng(dataPhoto.latitude,
          dataPhoto.longitude);
      var marker = new google.maps.Marker({
        position: latLng
      });
      markers.push(marker);
    }
    var markerCluster = new MarkerClusterer(map, markers);
  }
  google.maps.event.addDomListener(window, 'load', initialize);
-->
</script>

当然在我的html源代码中:

<html>
   <div id="map-container"><div id="map"></div></div>
<html>

2 个答案:

答案 0 :(得分:1)

你需要逃避花括号,以便你的XQuery处理器不会将它们视为XQuery。要逃避大括号,请重复一遍。而不是:

function initialize() {

...使用:

function initialize() {{

或者,您可以通过在与XQuery分开的.js文件中引用它来保持javascript完整/未修改。

答案 1 :(得分:1)

如果您使用Zorba,可以为您的JS代码序列化JSON值:

let $obj := { "data": [1, 2, 3]}
return <script>
  var data = {serialize($obj, ())};
</script>

您可以在http://www.zorba-xquery.com/html/demo#+Ic0lo+4mIEhji0Z0GujBQ==

上看到此示例