gpt4 book ai didi

javascript - 缩放到 openlayers 中的搜索功能

转载 作者:行者123 更新时间:2023-11-30 20:51:12 25 4
gpt4 key购买 nike

我创建了一个 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com