Я пытаюсь применить некоторые шаблоны проектирования OO к существующему скрипту, а после выполнения некоторых руководств в справочном центре Mozilla я все еще получаю сообщение об ошибке при попытке создать экземпляр объекта.Объект не является конструктором Ошибка JavaScript
Я просмотрел эти ресурсы для получения помощи, но, возможно, я не полностью понимаю синтаксис JavaScript.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Introduction_to_Object-Oriented_JavaScript
Ошибка:
Uncaught TypeError: GeoLocMap is not a constructor
Строка ошибки:
var GeoLocMap = new GeoLocMap();
Если каждый из методов ниже быть определена в качестве прототипа?
Спасибо за помощь!
Код:
function GeoLocMap() {
this.map = -1;
this.regionName = "";
this.options = -1;
this.openCountData = -1;
this.chart = -1;
this.getMap = function() {
if (this.map == -1) {
this.map = new google.maps.Map(document.getElementById('geochart-colors'), {
zoom: 6,
//TODO replace with the region retrieved from eventData
center: new google.maps.LatLng(lat, long),
mapTypeId: google.maps.MapTypeId.ROADMAP
});
} else {
return this.map;
}
};
this.getMapWidth = function() {
var docBody = document.body;
var docElem = document.documentElement;
if (typeof document.width !== 'undefined') {
return document.width;// For webkit browsers
} else {
return Math.max(docBody.scrollWidth, docBody.offsetWidth, docElem.clientWidth, docElem.scrollWidth, docElem.offsetWidth);
}
};
this.getMapHeight = function() {
var docBody = document.body;
var docElem = document.documentElement;
if (typeof document.height !== 'undefined') {
return document.height;// For webkit browsers
} else {
return Math.max(docBody.scrollHeight, docBody.offsetHeight, docElem.clientHeight, docElem.scrollHeight, docElem.offsetHeight);
}
};
this.getChart = function() {
if (this.chart == -1){
this.chart = new google.visualization.GeoChart(document.getElementById('geochart-colors'));
}
return this.chart;
};
this.getOpenCountData = function() {
if (this.openCountData == -1) {
var data = new google.visualization.DataTable();
data.addColumn('string', 'Country');
data.addColumn('number', 'Open Count');
this.openCountData = data;
}
return this.openCountData;
};
this.addOpenCountDataRow = function(dataRow) {
if (this.openCountData == -1){
this.getOpenCountData();
}
if (dataRow == -1){
return -1;
}
this.openCountData.addRows(dataRow);
return 1;
};
this.getOptions = function() {
if (this.options == -1) {
this.options = {
width: width,
height: height,
region: 'US',
resolution: 'provinces',
colors: ['#FFFFFF', '#FFFFFF']
};
}
return this.options;
};
this.setOptions = function (property, value) {
if (this.options == -1) {
this.getOptions();
}
if (value === undefined) {
return -1;
}
this.options[property] = value;
return 1;
};
this.drawMap = function() {
if (this.chart == -1){
this.getChart();
}
if (this.options == -1){
this.getOptions();
}
if (this.openCountData == -1){
this.getOpenCountData();
}
this.chart.draw(this.openCountData, this.options);
};
}
'вар GeoLocMap = новый GeoLocMap();'? И то же имя? –
Проблема в том, что вы переназначаете значение 'GeoLocMap' на этой строке. Таким образом, функция 'GeoLocMap' больше не будет работать и будет вместо этого экземпляра, вам нужно использовать другое имя переменной. –