Динамически создавать слои в листовке - PullRequest
0 голосов
/ 07 января 2019

Ниже приведен мой код для листовки, которая в настоящее время имеет три слоя. Код просто повторяется для каждого слоя, переименовывая функции в style, style2 style3 и т. Д. Однако количество слоев и их названия меняются, поэтому мне нужно создавать слои динамически. Как я могу обновить приведенный ниже код, чтобы я мог просто перебирать массив layer_names и избегать дублирования стиля функций, highlightFeature, resetHighlight, onEachFeature?

Мне нужно использовать ES2015 или старше, пожалуйста.

// initialise map
var map = L.map('map').setView([54.8, -3], 6);

var color_bins = {
    'GVA': [0, 5, 10, 15, 20, 30, 50, 70],
    'Employment': [0, 50, 100, 150, 200, 250, 300, 500],
    'Business sites': [0, 10, 20, 40, 60, 80, 100, 150]
}

function getColor(d, vals) {
    var grad_cols = ['#FFEDA0', '#FED976', '#FEB24C', '#FD8D3C', '#FC4E2A', '#E31A1C', '#BD0026', '#800026'];
    if (d >= vals[vals.length-1]) {
        return grad_cols[vals.length-1];
    }
    for (var i=0; i < (vals.length -1); i++) {
        // console.log(vals[i]);
        if (d >= vals[i] && d < vals[i+1]) {
            return grad_cols[i];
        }    
    }    
}        

var layer_names = ['GVA', 'Employment', 'Business sites'];

// GVA layer
var geojson;

function style(feature) {
    return {
        fillColor: getColor(feature.properties['GVA'], color_bins['GVA']),
        weight: 2,
    };
}

// specify hover effects
function highlightFeature(e) {
    var layer = e.target;

    layer.setStyle({
        weight: 3,
    });    

    if (!L.Browser.ie && !L.Browser.opera && !L.Browser.edge) {
        layer.bringToFront();
    }    
    info.update(layer.feature.properties);
}    

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

function onEachFeature(feature, layer) {
    layer.on({
        mouseover: highlightFeature,
        mouseout: resetHighlight,
    });    
}    

// add the choropleth layer
geojson = L.geoJson(statesData, {
    style: style,
    onEachFeature: onEachFeature
}).addTo(map);


// employment layer
var geojson2;

function style2(feature) {
    return {
        fillColor: getColor(feature.properties['Employment'], color_bins['Employment']),
        weight: 2,
    };
}

// specify hover effects
function highlightFeature2(e) {
    var layer = e.target;

    layer.setStyle({
        weight: 3,
    });

    if (!L.Browser.ie && !L.Browser.opera && !L.Browser.edge) {
        layer.bringToFront();
    }
    info.update(layer.feature.properties);
}

function resetHighlight2(e) {
    geojson2.resetStyle(e.target);
    info.update();
}

function onEachFeature2(feature, layer) {
    layer.on({
        mouseover: highlightFeature2,
        mouseout: resetHighlight2,
    });
}

// add the choropleth layer
geojson2 = L.geoJson(statesData, {
    style: style2,
    onEachFeature: onEachFeature2
});

// business sites layer
var geojson3;

function style3(feature) {
    return {
        fillColor: getColor(feature.properties['Business sites'], color_bins['Business sites']),
        weight: 2,
    };
}

// specify hover effects
function highlightFeature3(e) {
    var layer = e.target;

    layer.setStyle({
        weight: 3,
    });

    if (!L.Browser.ie && !L.Browser.opera && !L.Browser.edge) {
        layer.bringToFront();
    }
    info.update(layer.feature.properties);
}

function resetHighlight3(e) {
    geojson3.resetStyle(e.target);
    info.update();
}

function onEachFeature3(feature, layer) {
    layer.on({
        mouseover: highlightFeature3,
        mouseout: resetHighlight3,
    });
}

// add the choropleth layer
geojson3 = L.geoJson(statesData, {
    style: style3,
    onEachFeature: onEachFeature3
});

// add layers control
var overlays = {
    "GVA": geojson,
    "Employment": geojson2,
    "Business sites": geojson3
};
L.control.layers(overlays, null, { collapsed: false }).addTo(map);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...