我的代碼在本地部署時起作用,但當我將其部署到github頁面時,它不起作用。在calculateRadius()函數中,我調用setRadius()函數,該函數將一個半徑分配給Google地圖圈。當我運行調用這個函數,我得到一個錯誤說「遺漏的類型錯誤:無法讀取的未定義的屬性‘setRadius’」請參見下面的代碼:下面的代碼Uncaught TypeError:無法讀取未定義的屬性'setRadius'
<!DOCTYPE html>
<html>
<head>
<style>
#map {
height: 400px;
width: 100%;
}
</style>
</head>
<body>
<div id="map"></div>
<div id="datetime">
Number: <input type="number" id="areaChange" value="0">
</br>
<form onsubmit="calculateRadius(); return false;">
Select a date after January, 1 2010
</br>
Date: <input type="date" id="date" value="" min="2010-01-01">
<button id="btn">Click</button>
</form>
<button id="resetBtn">Reset</button>
<p id="data"></p>
</div>
<script>
var areaRate = 1648.91;
var circle;
var today;
var date1;
var date2;
var timeDiff;
var diffDays;
var timePassed;
var interval;
var intervalRate = 1000;
function setRadius() {
circle.setRadius(parseInt(document.getElementById("areaChange").value, 10));
}
function calculateRadius() {
document.getElementById("data").innerHTML = document.getElementById("date").value;
today = new Date();
date1 = new Date(document.getElementById("date").value);
date2 = today;
timeDiff = Math.abs(date2.getTime() - date1.getTime());
diffDays = Math.ceil(timeDiff/(1000));
timePassed = areaRate * diffDays;
console.log(intervalRate);
interval = setInterval(function() {
var radius = Math.sqrt(timePassed/Math.PI);
document.getElementById("areaChange").value = radius;
console.log(timePassed);
setRadius();
timePassed += areaRate;
}, intervalRate);
}
document.getElementById("resetBtn").addEventListener("click", function() {
clearInterval(interval);
console.log(interval);
});
function initMap() {
var styler = [{
"featureType": "road",
"elementType": "all",
"stylers": [{
"visibility": "off"
}]
}, {
"featureType": "administrative.country",
"elementType": "all",
"stylers": [{
"visibility": "on"
}, {
"invert_lightness": true
}]
}, {
"featureType": "administrative.province",
"elementType": "all",
"stylers": [{
"visibility": "simplified"
}, {
"invert_lightness": true
}, {
"weight": 1.43
}]
}, {
"featureType": "poi",
"elementType": "all",
"stylers": [{
"visibility": "off"
}]
}, {
"featureType": "administrative.neighborhood",
"elementType": "all",
"stylers": [{
"visibility": "off"
}]
}, {
"featureType": "administrative.land_parcel",
"elementType": "all",
"stylers": [{
"visibility": "off"
}]
}, {
"featureType": "poi.park",
"elementType": "all",
"stylers": [{
"visibility": "on"
}]
}, {
"featureType": "water",
"elementType": "all",
"stylers": [{
"visibility": "on"
}, {
"color": "#44a9b0"
}]
}, {
"featureType": "landscape.man_made",
"elementType": "all",
"stylers": [{
"color": "#e3e0bf"
}]
}];
var detroit = {
lat: 42.271084,
lng: -83.737277
};
var map = new google.maps.Map(document.getElementById('map'), {
zoom: 2,
center: detroit,
styles: styler
});
var pos;
navigator.geolocation.getCurrentPosition(function(position) {
pos = {
lat: position.coords.latitude,
lng: position.coords.longitude
};
map.setCenter(pos);
circle = new google.maps.Circle({
map: map,
center: pos,
radius: parseInt(document.getElementById("areaChange").value),
editable: false,
draggable: true,
geodesic: true,
strokeColor: 'transparent',
strokeOpacity: 1,
strokeWeight: 2,
fillColor: '#FF4136',
fillOpacity: 0.5
});
});
var time = document.getElementById('areaChange');
time.addEventListener('input', setRadius);
}
</script>
<script async defer
src="https://maps.googleapis.com/maps/api/js?callback=initMap">
</script>
它似乎是從GitHub頁面的問題。我將在不同的主機中託管我的頁面。 – Ibarrameade