Leaflet Popup GetContent (преобразование метров в футы)

Я создаю приложение, используя буклет, и у меня почти нулевой опыт работы с javascript, так что терпите меня ...

У меня есть карта-буклет и работает служба веб-функций, содержащая данные потока USGS, однако вся информация выражается в метрах, и я хочу преобразовать ее в футы и показать результат во всплывающем окне.

<html>
<head>
  <meta charset=utf-8 />
  <title>Leaflet Map</title>
  <meta name='viewport' content='initial-scale=1,maximum-scale=1,user-scalable=no' />

  <!-- Load Leaflet from CDN-->
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/leaflet/1.0.0-rc.1/leaflet.css" />
  <script src="https://cdn.jsdelivr.net/leaflet/1.0.0-rc.1/leaflet-src.js"></script>

  <!-- Load Esri Leaflet from CDN -->
  <script src="https://cdn.jsdelivr.net/leaflet.esri/2.0.0/esri-leaflet.js"></script>

  <style>
    body { margin:0; padding:0; }
    #map { position: absolute; top:0; bottom:0; right:0; left:0; }
  </style>
</head>
<body>

<div id="map"></div>

<script>
  var map = L.map("map").setView([37.75, -122.23], 10);


  L.esri.basemapLayer("Topographic").addTo(map);
  var gauges = L.esri.featureLayer({
    url: 'https://services.arcgis.com/lGOekm0RsNxYnT3j/arcgis/rest/services/north_america_surface_water_values/FeatureServer/4'
  }).addTo(map);

  gauges.bindPopup(function(evt){
    return L.Util.template('<p>Current Level:{LEVEL_CURRENT} </p>', evt.feature.properties);
  });
</script>

</body>
</html

Я прочитал документацию Leaflet, и в ней кое-что упоминалось о getContent ... Я знаю, что это, вероятно, очень просто, но я парень Python и ничего не знаю о JS, поэтому даже толчок в правильном направлении был бы отличным!

Спасибо за помощь!


person Judson    schedule 23.06.2016    source источник


Ответы (1)


Вы можете попробовать вычислить преобразование, сохранить его как объект и использовать его для рендеринга в шаблоне, или вы можете просто добавить current_level в feat в качестве дополнительного свойства в свой объект свойства features.

Я думаю, что в вашем случае первый вариант может быть проще, так как вы, кажется, заботитесь только об одном свойстве.

gauges.bindPopup(function(evt){
  var current_level = {
    in_feet: parseInt(evt.feature.properties.LEVEL_CURRENT*3.28084)
  };
  return L.Util.template('<p>Current Level: {in_feet}</p>', current_level);
});
person BrianDiesel    schedule 23.06.2016
comment
Потрясающий! Это сработало ... определенно собираюсь начать изучать JS после того, как закончу с этим проектом. Еще раз спасибо! - person Judson; 23.06.2016