我创建了一个 openlayers map 并使用了 bootstrap 搜索控件。单击搜索按钮后, map 将具有缩放范围,但整个 map 再次刷新。 下面是我写的源码...
<div class="input-group add-on">
<input class="form-control" placeholder="Search" name="srch-term" id="srch-term" type="text" onkeypress="autoFill()"/>
<div class="input-group-btn">
<button class="btn btn-default" type="submit" onclick="searchStateName();"><i class="glyphicon glyphicon-search"></i></button>
</div>
</div>
function searchStateName() {
input = document.getElementById("srch-term").value.toUpperCase();
if (input) {
for (var i = 0; i < countryData.length; i++) {
//alert(countryData[0]);
if (countryData[i].P.name_1.toUpperCase() == input) {
alert(countryData[i].P.name_1);
var extent = countryData[i].P.geom.getExtent();
map.getView().fit(extent, map.getSize());
if (countryData[i] !== highlight) {
if (highlight) {
featureOverlay.getSource().removeFeature(highlight);
}
if (countryData[i]) {
featureOverlay.getSource().addFeature(countryData[i]);
}
highlight = countryData[i];
}
}
}
}
}
谁能帮我看看问题出在哪里
最佳答案
循环检查你的代码:
if (countryData[i] !== highlight) {
if (highlight) {
featureOverlay.getSource().removeFeature(highlight);
}
if (countryData[i]) {
featureOverlay.getSource().addFeature(countryData[i]);
}
highlight = countryData[i];
}
hightlight
是一个普通变量,不是吗?它始终保留最后创建的特征。但是您在循环中每次都删除之前创建的特征, map 最后将只有一个特征。
关于javascript - 缩放到 openlayers 中的搜索功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48163391/