如何在传单地图上以图形方式映射JSON数据? [英] How to map JSON data graphically on a Leaflet map?

查看:61
本文介绍了如何在传单地图上以图形方式映射JSON数据?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想使用Citybik.es API( http://api.citybik.es/ )以在传单地图上显示数据.

I want to use the Citybik.es API (http://api.citybik.es/) to show data on a Leaflet map.

如何通过JSON在地图上实现此数据?我已经从componentDidMount()内部的API中获取信息,但是我不知道将这些数据放入地图中的任何线索. .

How do implement this data on the map from JSON? I am already fetching information from the API inside a componentDidMount(), but I don't have a clue about putting this data into a map.

响应看起来像这样:

{
  "networks": [
{
  "company": [
    "Bike U Sp. z o.o."
  ], 
  "href": "/v2/networks/bbbike", 
  "id": "bbbike", 
  "location": {
    "city": "Bielsko-Bia\u0142a", 
    "country": "PL", 
    "latitude": 49.8225, 
    "longitude": 19.044444
  }, 
  "name": "BBBike"
}, 
{
  "company": [
    "PBSC", 
    "Alta Bicycle Share, Inc"
  ], 
  "href": "/v2/networks/melbourne-bike-share", 
  "id": "melbourne-bike-share", 
  "location": {
    "city": "Melbourne", 
    "country": "AU", 
    "latitude": -37.814107, 
    "longitude": 144.96328
  }, 
  "name": "Melbourne Bike Share"
}
}

感谢您的帮助!

import React, { Component } from 'react';
import L from 'leaflet';
import { Map, TileLayer, Marker, Popup } from 'react-leaflet';

// code for map marker icon
var myIcon = L.icon({
    iconUrl: '',
    iconSize: [25, 41],
    iconAnchor: [12.5, 41],
    popupAnchor: [0, -41]
});

class App extends Component {
    state = {
        location: {
            lat: 51.505,
            lng: -0.09,
        },
        haveUsersLocation: false,
        zoom: 2,
        networks: null
    }

    //lifecycle method to get the user's current position(if they so desire).
    componentDidMount() {

        fetch('https://api.citybik.es/v2/networks')
        .then(res => res.json())
        .then(response => {
            console.log("response", response);
            console.log(response.networks)
            const networkData = response.networks
            const networkList = networkData.map((data) => {
                console.log(data);
            })
    })


        navigator.geolocation.getCurrentPosition((position) => {
            this.setState({
               location: {
                   lat: position.coords.latitude,
                   lng: position.coords.longitude
               },
               haveUsersLocation: true,
               zoom: 13
            });
        }, () => {
            console.log('Uops! The user didnt give its location!');
            fetch('https://ipapi.co/json')
            .then(res => res.json())
            .then(location => {
                this.setState({
                    location: {
                        lat: location.latitude,
                        lng: location.longitude
                    },
                    haveUsersLocation: true,
                    zoom: 13
                 });
            })
        });
    }


    render() {
        const position = [this.state.location.lat, this.state.location.lng]
        return (
            <Map className="map" center={position} zoom={this.state.zoom}>
                <TileLayer
                    attribution="&amp;copy <a href=&quot;http://osm.org/copyright&quot;>OpenStreetMap</a> contributors"
                    url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
                />
                {
                    this.state.haveUsersLocation ? 
                    <Marker
                        position={position}
                        icon={myIcon}>
                    <Popup>
                        A pretty CSS3 popup. <br /> Easily customizable.
                    </Popup>
                </Marker> : ''
                }
            </Map>
        )
    }
}

ReactDOM.render(<App/>,
    document.getElementById('root')
);

body {
    margin: 0px;
    width: 100vw;
    height: 100vh;
}

#root {
    height: 100%;
}

.map {
    height: 100%;
}

<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/15.1.0/react-dom.min.js"></script>
<link href="https://unpkg.com/leaflet@1.3.4/dist/leaflet.css" rel="stylesheet"/>
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <meta name="theme-color" content="#000000">

    <title>Leaflet map</title>
  </head>
  <body>
    <div id="root"></div>
  </body>
</html>

推荐答案

您将不得不渲染多个Marker元素.当前,如果您具有当前用户位置,则正在渲染一个Marker.以类似的方式,我们将迭代其他坐标并进行渲染.

You'll have to render multiple Marker element. Currently, you are rendering one Marker if you have the current users location. In similar fashion, we will iterate through the other co-ordinates and render them.

在您的componentDidMount中,将收到的回复保存到一个状态

In your componentDidMount, save the response you receive to a state

fetch('https://api.citybik.es/v2/networks')
    .then(res => res.json())
    .then(response => {
        console.log("response", response);
        console.log(response.networks)
        const networkData = response.networks
        const networkList = networkData.map((data) => {
            this.setState({ bikeData: data });
        })
})

然后在您的render方法内部,遍历bikeData并呈现Markers.

Then inside your render method, iterate over the bikeData and render the Markers.

<Map className="map" center={position} zoom={this.state.zoom}>
            <TileLayer
                attribution="&amp;copy <a href=&quot;http://osm.org/copyright&quot;>OpenStreetMap</a> contributors"
                url="https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
            />
            {
                this.state.haveUsersLocation ? 
                <Marker
                    position={position}
                    icon={myIcon}>
                <Popup>
                    A pretty CSS3 popup. <br /> Easily customizable.
                </Popup>
            </Marker> : ''
            }

            {
              this.state.bikeData &&
              this.state.bikeData.networks.map((idx, data) => (
               <Marker key={data.id} position={[data.location.latitude, data.location.longitude]}> <Popup> Name: {data.name} </Popup> </Marker>))
            } 

        </Map>

这篇关于如何在传单地图上以图形方式映射JSON数据?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆