Leaflet 大 GeoJson 文件 Ajax 过滤最佳性能
Leaflet big GeoJson file Ajax filter best performance
我有四个 2MB 的 geoJson 文件,其中有四个层要加载
LayerBoon = L.geoJSON.ajax(URL, {pointToLayer:returnBoonMarker, filter:filtertext});
具有过滤功能和此按钮点击功能
$("#btnFindText").click(function(){
SeachTXT = $("#txtFind").val();
LayerSt.refresh();
LayerPr.refresh();
LayerHL.refresh();
LayerBoon.refresh();
})
每个图层都必须通过单击按钮重新过滤。
过滤的时候,能不能不用每次都重新加载文件,保存在缓存里再过滤?
最简单的方法是使用 fetch:
const api = 'json_boon.json';
async function fetchData(url) {
try {
const response = await fetch(url, { cache: "force-cache" });
const data = await response.json();
return data;
} catch (err) {
console.error(err);
}
};
fetchData(api)
.then(data => {
L.geoJson(data).addTo(map);
});
我添加了一个强制浏览器缓存文件的附加参数cache: "force-cache"
第一次下载正常,后面的都是从磁盘缓存中获取,方便检查devtools。
更新:
const geojsonOpts = {
pointToLayer: function (feature, latlng) {
return ...
},
filter: function(feature, layer) {
return ...
}
};
["one", "two", "three", "four"].map((json) => {
fetchData(`./${json}.json`).then((data) => {
L.geoJSON(data, geojsonOpts).addTo(map);
});
});
我有四个 2MB 的 geoJson 文件,其中有四个层要加载
LayerBoon = L.geoJSON.ajax(URL, {pointToLayer:returnBoonMarker, filter:filtertext});
具有过滤功能和此按钮点击功能
$("#btnFindText").click(function(){
SeachTXT = $("#txtFind").val();
LayerSt.refresh();
LayerPr.refresh();
LayerHL.refresh();
LayerBoon.refresh();
})
每个图层都必须通过单击按钮重新过滤。
过滤的时候,能不能不用每次都重新加载文件,保存在缓存里再过滤?
最简单的方法是使用 fetch:
const api = 'json_boon.json';
async function fetchData(url) {
try {
const response = await fetch(url, { cache: "force-cache" });
const data = await response.json();
return data;
} catch (err) {
console.error(err);
}
};
fetchData(api)
.then(data => {
L.geoJson(data).addTo(map);
});
我添加了一个强制浏览器缓存文件的附加参数cache: "force-cache"
第一次下载正常,后面的都是从磁盘缓存中获取,方便检查devtools。
更新:
const geojsonOpts = {
pointToLayer: function (feature, latlng) {
return ...
},
filter: function(feature, layer) {
return ...
}
};
["one", "two", "three", "four"].map((json) => {
fetchData(`./${json}.json`).then((data) => {
L.geoJSON(data, geojsonOpts).addTo(map);
});
});