javascript - 超过一张 "oneachfeature"传单

标签 javascript gis leaflet

我正在尝试将两个功能组合在一层上,但无法同时使用它们。一个是突出显示光标悬停的区域,另一个是在弹出窗口中获取信息。我使用了本指南来突出显示:http://leafletjs.com/examples/choropleth.html (添加交互部分,尝试将其合并到工作信息弹出层)。此外,目前它在悬停时突出显示,但如果它在单击时突出显示,那就太好了。 代码:

    function style(feature) {
    return {
        fillColor: 'blue',
        weight: 2,
        opacity: 1,
        color: 'grey',
        dashArray: '3',
        fillOpacity: 0.7
    };
}

    L.geoJson(piirid, {style: style});

    function highlightFeature(e) {
        var layer = e.target;

        layer.setStyle({
            weight: 5,
            color: '#666',
            dashArray: '',
            fillOpacity: 0.7
        });

        if (!L.Browser.ie && !L.Browser.opera) {
            layer.bringToFront();
        }
    }

    function resetHighlight(e) {
        geojson.resetStyle(e.target);
    }

    var geojson;
    // ... our listeners
    geojson = L.geoJson(piirid);

    function zoomToFeature(e) {
        map.fitBounds(e.target.getBounds());
    }

    function onEachFeature3(feature, layer) {
        layer.on({
            mouseover: highlightFeature,
            mouseout: resetHighlight,
            //click: zoomToFeature
        });
    }

    geojson = L.geoJson(piirid, {
        style: style,
        onEachFeature: onEachFeature,
        onEachFeature: onEachFeature3
    });

    function onEachFeature(feature, layer) {
        if (feature.properties) {
            layer.bindPopup("<br><b><big><u>Aadresss: " + feature.properties.L_AADRESS + "</br></b></big></u><br> <b>Maakond:&nbsp;</b>" + feature.properties.MK_NIMI
            + " <br><br>", {"offset":  [200, -50]});
        }

}

谢谢克里斯汀

最佳答案

将两个函数结合起来,它们使用相同的参数不妨完成为一个函数。

 function style(feature) {
        return {
            fillColor: 'blue',
            weight: 2,
            opacity: 1,
            color: 'grey',
            dashArray: '3',
            fillOpacity: 0.7
        };
    }

    L.geoJson(piirid, {style: style});

    function highlightFeature(e) {
        var layer = e.target;

        layer.setStyle({
            weight: 5,
            color: '#666',
            dashArray: '',
            fillOpacity: 0.7
        });

        if (!L.Browser.ie && !L.Browser.opera) {
            layer.bringToFront();
        }
    }

    function resetHighlight(e) {
        geojson.resetStyle(e.target);
    }

    var geojson;
    // ... our listeners
    geojson = L.geoJson(piirid);

    function zoomToFeature(e) {
        map.fitBounds(e.target.getBounds());
    }

    function onEachFeature3(feature, layer) {
        layer.on({
            mouseover: highlightFeature,
            mouseout: resetHighlight,
            //click: zoomToFeature
        });
        if (feature.properties) {
            layer.bindPopup("<br><b><big><u>Aadresss: " + feature.properties.L_AADRESS + "</br></b></big></u><br> <b>Maakond:&nbsp;</b>" + feature.properties.MK_NIMI
            + " <br><br>", {"offset":  [200, -50]});
        }
    }

    geojson = L.geoJson(piirid, {
        style: style,
        onEachFeature: onEachFeature3
    });

关于javascript - 超过一张 "oneachfeature"传单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21039243/

相关文章:

javascript - 更高的 JavaScript 精度

javascript - Sails.js,获取请求参数 json 对象

R:计算两个点层之间的最短距离

javascript - 如何使用 Typescript + react-leaflet 创建 GeoJSON Feature 元素

leaflet - 如何将 Leaflet 集成到 Angular 5 中

javascript - 通过javascript增加文本区域大小

javascript - 如何从数组中删除/过滤特定项目?

postgresql - 绕其局部轴旋转几何体

google-maps - 如何设置透明叠加 WMS 图层的样式

javascript - 传单版本 1.0.2 中未触发事件 View 重置