将 innerHTML 设置为 Null 属性
2017-07-04
149
我一直试图将 openweathermap 的 api 数据与 google map 的 api 数据合并。但是,每当我尝试使用 innerHTML 从 api 获取数据时,它都会显示
Uncaught TypeError: Cannot set property 'innerHTML' of null
。
Javascript
var map;
var weather;
var temp;
var APPID = 'e9e239c6585f081bee7b0d7f6045a53f';
function updateByCity(q) {
var url = "http://api.openweathermap.org/data/2.5/weather?q={" +
q +
"}&APPID=" + APPID;
sendRequest(url);
}
function sendRequest(url) {
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
var data = JSON.parse(xmlhttp.responseText);
var weather = {};
weather.temp = data.main.temp;
update(weather);
}
};
xmlhttp.open("GET", url, true);
xmlhttp.send();
}
function update(weather) {
temp.innerHTML = weather.temp;
}
window.onload = function() {
temp = document.getElementById("temperature");
var weather = {};
weather.temp = "35";
update(weather);
}
function initMap() {
var KL = {
lat: 3.1390,
lng: 101.6869
};
var map = new google.maps.Map(document.getElementById('map'), {
zoom: 6,
center: {
lat: 4.444997,
lng: 106.554199
}
});
var marker = new google.maps.Marker({
position: KL,
map: map
});
var contentString = '<div id="content">' +
'<div id="siteNotice">' +
'</div>' +
'<h1 id="firstHeading" class="firstHeading">Kuala Lumpur</h1>' +
'<div id="bodyContent">' +
'<p>Temperature: ' + temp + '</p>' +
'</div>' +
'</div>';
var infowindow = new google.maps.InfoWindow({
content: contentString
});
marker.addListener('click', function() {
infowindow.open(map, marker);
});
}
HTML
<!doctype>
<html>
<head>
<script src="mapJS.js"></script>
<script async defer src="https://maps.googleapis.com/maps/api/js?key=AIzaSyBuhL2_brcvjW12heXCPV8G-lXd7Kmue84&callback=initMap">
</script>
<title>Simple Map</title>
<meta name="viewport" content="initial-scale=1.0">
<meta charset="utf-8">
<style>
#map {
height: 100%;
}
html,
body {
height: 100%;
margin: 0;
padding: 0;
}
</style>
<div id="map"></div>
</head>
</html>
2个回答
这应该可以解决您的
null
设置属性问题。主要原因是您忘记创建一个元素来设置温度读数。因此我创建了一个新的
<div id="temperature">
,它解决了这个问题。
var map;
var weather;
var temp;
var APPID = 'e9e239c6585f081bee7b0d7f6045a53f';
function updateByCity(q) {
var url = "http://api.openweathermap.org/data/2.5/weather?q={" +
q +
"}&APPID=" + APPID;
sendRequest(url);
}
function sendRequest(url) {
var xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
var data = JSON.parse(xmlhttp.responseText);
var weather = {};
weather.temp = data.main.temp;
update(weather);
}
};
xmlhttp.open("GET", url, true);
xmlhttp.send();
}
function update(weather) {
temp.innerHTML = weather.temp;
}
window.onload = function() {
temp = document.getElementById("temperature");
var weather = {};
weather.temp = "35";
update(weather);
}
function initMap() {
var KL = {
lat: 3.1390,
lng: 101.6869
};
var map = new google.maps.Map(document.getElementById('map'), {
zoom: 6,
center: {
lat: 4.444997,
lng: 106.554199
}
});
var marker = new google.maps.Marker({
position: KL,
map: map
});
var contentString = '<div id="content">' +
'<div id="siteNotice">' +
'</div>' +
'<h1 id="firstHeading" class="firstHeading">Kuala Lumpur</h1>' +
'<div id="bodyContent">' +
'<p>Temperature: ' + temp + '</p>' +
'</div>' +
'</div>';
var infowindow = new google.maps.InfoWindow({
content: contentString
});
marker.addListener('click', function() {
infowindow.open(map, marker);
});
}
////////////////////////////////////////////////////
<!doctype>
<html>
<head>
<script src="mapJS.js"></script>
<script async defer src="https://maps.googleapis.com/maps/api/js?key=AIzaSyBuhL2_brcvjW12heXCPV8G-lXd7Kmue84&callback=initMap">
</script>
<title>Simple Map</title>
<meta name="viewport" content="initial-scale=1.0">
<meta charset="utf-8">
<style>
#map {
height: 100%;
}
html,
body {
height: 100%;
margin: 0;
padding: 0;
}
</style>
<br>
<div id="temperature"></div><br>
<div id="map"></div>
</head>
</html>
Kakashi Hatake
2017-07-04
在您的
onload
函数中,您定位了 HTML ID
temperature
,但它不存在,我认为您想要定位
map
window.onload = function() {
temp = document.getElementById("map");
var weather = {};
weather.temp = "35";
update(weather);
}
Junaid
2017-07-04