- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个应用程序,您可以在其中单击 Google map 标记图钉,它会自动将信息窗口内容填充到文本框中。但是,我似乎无法进行信息传输。我已经进行了广泛的搜索,试图解决这个问题,但到目前为止还没有成功 - 特别是因为涉及多个文本框。如果有任何帮助,我将不胜感激。
这是 HTML 代码:
<!-- Map -->
<div id="mapDiv"></div><br />
<!-- Destinations -->
<div id="destination1">
<label class="title">Destination 1:</label>
<input id="dest-num1" type="text" name="dest1" size="50" />
</div><br />
<div id="destination2">
<label class="title">Destination 2:</label>
<input id="dest-num2" type="text" name="dest2" size="50" />
</div><br />
这是我的 JavaScript:
var map;
function initMap(){
google.maps.visualRefresh = true;
var mapOptions = {
center: new google.maps.LatLng(37.09948, -95.59307),
zoom: 4,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var mapElement = document.getElementById('mapDiv');
map = new google.maps.Map(mapElement, mapOptions);
var markers = [
['BHM-Birmingham', 33.56243, -86.75413],
['HSV-Huntsville', 34.64033, -86.77569],
['PHX-Phoenix', 33.43727, -112.00779],
['TUS-Tucson', 32.11451, -110.93923]
];
var infoWindowContent = [
['<div class="info_content">' + '<p>Birmingham, AL (BHM - Birmingham-Shuttlesworth Intl)</p>' + '</div>'],
['<div class="info_content">' + '<p>Huntsville, AL (HSV - Huntsville Intl)</p>' + '</div>'],
['<div class="info_content">' + '<p>Phoenix, AZ (PHX - Phoenix Sky Harbor Intl)</p>' + '</div>'],
['<div class="info_content">' + '<p>Tucson, AZ (TUS - Tucson Intl)</p>' + '</div>'],
];
var infoWindow = new google.maps.InfoWindow(), marker, i;
for(i=0; i < markers.length; i++){
var position = new google.maps.LatLng(markers[i][1], markers[i][2]);
var image = 'images/airportIcon_red.png';
var marker = new google.maps.Marker({
position: position,
map: map,
icon: image,
title: markers[i][0],
draggable: false,
});
google.maps.event.addListener(marker, 'click', (function(marker, i) {
return function() {
infoWindow.setContent(infoWindowContent[i][0]);
infoWindow.open(map, marker);
if (!"dest-num1".val()) {
document.getElementById("dest-num1").value = infoWindowContent;
if (!"dest-num2".val()) {
document.getElementById("dest-num2").value = infoWindowContent;
if (!"dest-num1".val() && !"dest-num2".val()) {
alert ("One of the destination fields must be cleared before a new destination can be selected");
}
}
}
}
})(marker, i));
}
}
google.maps.event.addDomListener(window, 'load', initMap);
预先感谢您的帮助!
最佳答案
您错误地使用了 JQuery:
if (!"dest-num1".val()) {
document.getElementById("dest-num1").value = infoWindowContent;
if (!"dest-num2".val()) {
document.getElementById("dest-num2").value = infoWindowContent;
if (!"dest-num1".val() && !"dest-num2".val()) {
alert ("One of the destination fields must be cleared before a new destination can be selected");
}
}
}
应该是(注意 $(#...),val() 与 "dest-num1".val()):
if (!$("#dest-num1").val()) {
document.getElementById("dest-num1").value = markers[i][0];
} else if (!$("#dest-num2").val()) {
document.getElementById("dest-num2").value = markers[i][0];
} else {
alert("One of the destination fields must be cleared before a new destination can be selected");
}
var map;
function initMap() {
google.maps.visualRefresh = true;
var mapOptions = {
center: new google.maps.LatLng(37.09948, -95.59307),
zoom: 4,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var mapElement = document.getElementById('mapDiv');
map = new google.maps.Map(mapElement, mapOptions);
var markers = [
['BHM-Birmingham', 33.56243, -86.75413],
['HSV-Huntsville', 34.64033, -86.77569],
['PHX-Phoenix', 33.43727, -112.00779],
['TUS-Tucson', 32.11451, -110.93923]
];
var infoWindowContent = [
['<div class="info_content">' + '<p>Birmingham, AL (BHM - Birmingham-Shuttlesworth Intl)</p>' + '</div>'],
['<div class="info_content">' + '<p>Huntsville, AL (HSV - Huntsville Intl)</p>' + '</div>'],
['<div class="info_content">' + '<p>Phoenix, AZ (PHX - Phoenix Sky Harbor Intl)</p>' + '</div>'],
['<div class="info_content">' + '<p>Tucson, AZ (TUS - Tucson Intl)</p>' + '</div>'],
];
var infoWindow = new google.maps.InfoWindow(),
marker, i;
for (i = 0; i < markers.length; i++) {
var position = new google.maps.LatLng(markers[i][1], markers[i][2]);
// var image = 'images/airportIcon_red.png';
var marker = new google.maps.Marker({
position: position,
map: map,
// icon: image,
title: markers[i][0],
draggable: false,
});
google.maps.event.addListener(marker, 'click', (function(marker, i) {
return function() {
infoWindow.setContent(infoWindowContent[i][0]);
infoWindow.open(map, marker);
var value = $("#dest-num1").val();
if (!$("#dest-num1").val()) {
document.getElementById("dest-num1").value = markers[i][0];
} else if (!$("#dest-num2").val()) {
document.getElementById("dest-num2").value = markers[i][0];
} else {
alert("One of the destination fields must be cleared before a new destination can be selected");
}
}
})(marker, i));
}
}
google.maps.event.addDomListener(window, 'load', initMap);
html,
body,
#mapDiv {
height: 500px;
width: 500px;
margin: 0px;
padding: 0px
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://maps.googleapis.com/maps/api/js"></script>
<!-- Map -->
<div id="mapDiv"></div>
<br />
<!-- Destinations -->
<div id="destination1">
<label class="title">Destination 1:</label>
<input id="dest-num1" type="text" name="dest1" size="50" />
</div>
<br />
<div id="destination2">
<label class="title">Destination 2:</label>
<input id="dest-num2" type="text" name="dest2" size="50" />
</div>
<br />
关于javascript - 如何将 Google Maps InfoWindow 数据放入多个 HTML 文本框中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29222672/
我正在为一个网站开发应用程序(我无法访问该网站)。 所以我想做以下事情: 那么如何将文本数据从 Android View 传递到网页中的文本框并捕获来自网站的响应? 我试图记住这一切我无法访问任何网站
我有一个文本框,里面有一个很长的 url。我想做的是,当用户点击主页按钮时,我希望光标移动到文本框的开头。 我希望这是正常行为,但事实并非如此,当文本框内的文本很长时,我点击回家,它会转到文本框中当前
我正在做一个WPF登录界面。在我的登录面板中,我有一个登录 TextBox和 PasswordBox .如下图第一张所示,登录文本框中有一个小人类标志,密码框中有一个锁。我将图像设置为文本框背景,然后
是否有任何简单的方法可以使文本在文本框中居中?我正在寻找一些内置函数,但什么也没找到。 最佳答案 将 TextAlignment 属性设置为 Center: 关于wpf - 文本框 - 水平文本居中
是否可以使用 System.Windows.Forms.TextBox(或任何其他方法)输入可随后转换为安全字符串的文本?我希望能够获取输入的值,将其转换为安全字符串并将其写入一个文件,然后可以在需要
是否可以使用 System.Windows.Forms.TextBox(或任何其他方法)输入可随后转换为安全字符串的文本?我希望能够获取输入的值,将其转换为安全字符串并将其写入一个文件,然后可以在需要
我想将纬度和经度的值返回到我的 EditText 中,我已经能够使用 Toast 来做到这一点,但没有通过 实现它>编辑文本。请帮忙 // EditText latEditText =
我是Jquery新手,其实我对JQuery的使用知识是0。我正在尝试使用 JQuery 来实现某些功能。 我有一个带有 iframe 的 html 页面。 iframe 页面中有一个表单和一个文本框。
我正在尝试在 Button 的事件处理程序中访问我在 C# 中动态创建的 TextBox。 void MainFormLoad(object sender, EventArgs e)
我有一个搜索栏,当我打开搜索栏时,我想立即开始输入,不想点击文本框。 我尝试使用 myTextBoxId.click()(因为当您单击它时,您可以开始输入)但它不起作用。 最佳答案 你必须 docum
我还没有找到好的解决方案:我有一个文本框,用户需要能够在其中输入特定 信息。例如,命令可能是“9030 OUT FU [1234 TEST]”。我需要“擦洗”这个文本框以确保数据是以这种格式输入的(不
我有一个 Java 应用程序,您可以在其中将字符串输入文本框,点击加密,它会在单独的文本框中显示加密的字符串。我将为此使用 AES 加密。问题是我无法让加密文本按字节显示,但文本框不会显示字节(仅采用
我已经浏览了您庞大的问题数据库,但似乎没有找到答案。我在将文本换行时遇到问题 - 即使之前的行上仍有空间。这是代码: p1 { border-left: 6px solid blue; bac
所以我正在尝试创建“看板/待办事项列表”网站,但我在触发添加按钮时遇到了问题。我试图触发“添加”按钮以打开用户输入框。所以我有这个创建一个小框的“添加”按钮。但我无法弄清楚如何在该框中添加一个小区域,
我有一个文本框,应该只接受浮点值。它不应该允许任何其他值。怎么做。我在 HTML 中完成了此操作。 Weight 但是,它不起作用?如何做到这一点。 最佳答案 // remo
当用户点击文本框时,如何不显示出现在文本框下方的已填充值 最佳答案 将这个属性放在你的文本框中 autocomplete="off" 关于javascript - 文本框 - 如何不显示已填充的值,我
JavaScript: function resize(elem){ if(!elem.value.length) elem.size=1; else elem.size=elem.value
在我的代码下面,我需要它具有相同的宽度和高度,但有多行“从第一行开始”,当到达行尾时转到新行,只有 120 个字符,就像我用“Enter短信”当您向右单击时隐藏,但我需要它为灰色。 最佳答案 您可以使
我有一个问题,我必须创建一种方法来搜索显示在多个文本框 (lblResult.Text) 中的选定文本文件的内容。使用简单的搜索算法:搜索用户输入的整个搜索词。例如,如果用户输入“hello”,则只搜
我正在尝试对文本框使用 SelectionStart 和 SelectionLength 属性。它没有效果,但也没有错误。它实际上是后台工作程序 ProgressChanged 方法的一部分,但我已经
我是一名优秀的程序员,十分优秀!