Leaflet Popup GetContent(将米转换为英尺)
Leaflet Popup GetContent (Convert meters to feet)
我正在使用传单创建一个应用程序,我的 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 一无所知,所以即使朝着正确的方向推进也会很棒!
感谢您的帮助!
您可以尝试计算转化率,将其存储为一个对象并使用它呈现到您的模板,或者您可以在 feat 中附加一个 current_level 作为附加的 属性 在您的功能上属性 对象。
我认为第一个选项可能更容易,在你的情况下,因为你似乎只关心那个 属性。
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);
});
我正在使用传单创建一个应用程序,我的 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 一无所知,所以即使朝着正确的方向推进也会很棒!
感谢您的帮助!
您可以尝试计算转化率,将其存储为一个对象并使用它呈现到您的模板,或者您可以在 feat 中附加一个 current_level 作为附加的 属性 在您的功能上属性 对象。
我认为第一个选项可能更容易,在你的情况下,因为你似乎只关心那个 属性。
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);
});