Использование jQuery для извлечения CDATA в XML для использования в качестве содержимого HTML - PullRequest
2 голосов
/ 22 февраля 2010

Я извлекаю файл Google Earth .kml (xml) и использую его для размещения маркеров в Картах Google. Интересующие меня теги XML выглядят так:

<Placemark>
       <name>Bahamas-LSI</name>
       <description><![CDATA[
       <img src="http://coralreefwatch.noaa.gov/satellite/ge/data/current/vs_Bahamas_LSI.bmp">
       <p>
       - <a href="http://coralreefwatch.noaa.gov/satellite/virtual_stations/greater_caribbean.html#Bahamas_LSI">
         SST/DHW time series</a>.
       <p>
       - E-mail coralreefwatch@noaa.gov to subscribe free<br>automatic e-mail bleaching alert for this site.
       ]]></description>
       <Snippet></Snippet>
       <LookAt>
       <longitude>-76.5000</longitude>
       <latitude>23.5000</latitude>
       ..
</Placemark>

Следующий код извлекает имя и широту и длину, однако я не знаю, как извлечь CDATA из тега описания, используя jQuery. Я хотел бы иметь возможность извлечь фактический HTML, чтобы затем использовать его в информационном окне для маркера Карт Google.

// 
jQuery.get("CRWGE_current_products.kml", {}, function(data) {
  // for each placemark tag, extract the name & latlong
  // and then plot
  jQuery(data).find("placemark").each(function() {
    var station = jQuery(this);
    var name = station.find('name').text();
    var latlng = new google.maps.LatLng(parseFloat(station.find('latitude').text()),
                                      parseFloat(station.find('longitude').text()));

    // get html for station-specific data
    var content = station.find('description').text();
    console.log(content); <--- empty string

    setMarker(map, latlng, name, stressIcon, content)
  });
});

1 Ответ

3 голосов
/ 22 февраля 2010

Извлеките его в формате xml, и вы сможете правильно вызывать текст:

jQuery.get("CRWGE_current_products.kml", {}, function(data) { }, 'xml');

Я сделал это с помощью XML-каналов из USGS.gov, но я не пробовал это с .kml.

...