首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将状态传递给子组件的处理程序?

如何将状态传递给子组件的处理程序?
EN

Stack Overflow用户
提问于 2022-03-05 19:04:43
回答 1查看 77关注 0票数 0

GeoJson组件有一个函数onEachFeature,它调用一个处理程序,在本例中是createPopup

<GeoJSON data={covidGeoJSON} onEachFeature={createPopup}></GeoJSON>

在处理程序createPopup中,如何访问在CovidMap组件中定义的状态?

代码语言:javascript
复制
import React, { useState } from 'react'
import { MapContainer, GeoJSON } from 'react-leaflet'
import 'leaflet/dist/leaflet.css'



CovidMap = ({ covidGeoJSON, styles }) => {

    const showCords = (e) => {
        console.log(e.latlng);
    }

    const createPopup = (state, layer) => {
        layer.on({
            mouseover: showCords,
        });
        layer.bindPopup(state.properties.NAME);
    }

    const [range, setRange] = useState([]);

    return (
        <div>
            <MapContainer style={{ height: '90vh', width: '100vw' }} center={[39.162497380360634, -94.83672007881789]} zoom={5}>
                <GeoJSON data={covidGeoJSON} onEachFeature={createPopup}></GeoJSON>
            </MapContainer>
        </div>
    )
}

export default CovidMap
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-03-05 20:14:20

您应该能够从createPopup引用状态。使用CovidMap钩子在useState中创建和使用状态变量:

代码语言:javascript
复制
const CovidMap = () => {

    ...
    const [properties, setProperties] = useState({});
    const [layer, setLayer] = useState({});

    const createPopup = () => {
        layer.on({
            mouseover: showCords,
        });
        layer.bindPopup(properties.NAME);
    }
    ...
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71365187

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档