开发者问题收集

将 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