Я потратил много времени на настройку локального сервера тестирования сегодня, и после попытки установить кучу вещей вручную, я, наконец, решил просто использовать WampServer, что выглядит здорово.
После тестирования моего сайтаЯ был очень рад видеть, что весь PHP работает безупречно, но я заметил, что некоторые из javascript, похоже, не работают, а некоторые изображения не загружаются.
Все пути относительны- пути к изображениям в css выглядят так: url(img/btn_bg.png)
.Некоторые из них отображаются, некоторые нет, хотя они все находятся в одном и том же месте локально, и я могу получить к ним доступ через веб-браузер, если наберу путь / имя файла вручную.Все они появляются на удаленном сайте.Я проверил, чтобы убедиться, что пути не зависят от удаленного сайта (не абсолютные пути).
Я не совсем уверен, как проверить, что происходит с JavaScript.У меня есть firebug, но я не знаю, как использовать функции отладки.Я попробовал тестирование заглушки через оповещения, но безуспешно.Поскольку весь код JS находится в одном и том же файле, он работает правильно на удаленном сервере, и некоторые из них работают правильно локально, я не уверен, что с ним может происходить?Опять же, все пути относительны.
Поскольку этот проект является частным, мне не разрешается раскрывать большую часть кода, но вот несколько примеров:
function changeDiv()
{
var direction = arguments[0];
var tabs = new Array(
'basics', 'operations', 'info', 'contractinfo', 'contractsize',
'intent_tab', 'transportation', 'type', 'mep', 'materials',
'clinicalresearch', 'consulting', 'collaboration', 'construction',
'education', 'environmental', 'vendor', 'realestate', 'recs', 'fin');
var vis = new Array();
for ( a = 0; a < tabs.length; ++a )
{
var temp = tabs[a];
if (document.getElementById(temp).className.match('show'))
{
vis += tabs[a];
}
}
if (
vis == 'basics' || vis == 'operations' || vis == 'info' ||
vis == 'contractinfo' || vis == 'contractsize' || vis == 'intent_tab' ||
vis == 'transportation' || vis == 'materials' || vis == 'recs' ||
vis == 'fin' )
{
switch (vis)
{
case 'basics':
document.getElementById('operations').className =
document.getElementById('operations').className.
replace(/\bhide\b/, 'show');
document.getElementById('basics').className =
document.getElementById('basics').className.
replace(/\bshow\b/, 'hide');
document.getElementById('back_button').className =
document.getElementById('back_button').className.
replace(/\bhide\b/, 'show');
break;
case 'operations':
if (direction == 'next')
{
document.getElementById('info').className =
document.getElementById('info').className.
replace(/\bhide\b/, 'show');
document.getElementById('operations').className =
document.getElementById('operations').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('basics').className =
document.getElementById('basics').className.
replace(/\bhide\b/, 'show');
document.getElementById('operations').className =
document.getElementById('operations').className.
replace(/\bshow\b/, 'hide');
document.getElementById('back_button').className =
document.getElementById('back_button').className.
replace(/\bshow\b/, 'hide');
}
break;
case 'info':
if (direction == 'next')
{
document.getElementById('contractinfo').className =
document.getElementById('contractinfo').className.
replace(/\bhide\b/, 'show');
document.getElementById('info').className =
document.getElementById('info').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('operations').className =
document.getElementById('operations').className.
replace(/\bhide\b/, 'show');
document.getElementById('info').className =
document.getElementById('info').className.
replace(/\bshow\b/, 'hide');
}
break;
case 'contractinfo':
if (direction == 'next')
{
document.getElementById('contractsize').className =
document.getElementById('contractsize').className.
replace(/\bhide\b/, 'show');
document.getElementById('contractinfo').className =
document.getElementById('operations').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('info').className =
document.getElementById('info').className.
replace(/\bhide\b/, 'show');
document.getElementById('contractinfo').className =
document.getElementById('contractinfo').className.
replace(/\bshow\b/, 'hide');
}
break;
case 'contractsize':
if (direction == 'next')
{
document.getElementById('intent_tab').className =
document.getElementById('intent_tab').className.
replace(/\bhide\b/, 'show');
document.getElementById('contractsize').className =
document.getElementById('contractsize').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('contractinfo').className =
document.getElementById('contractinfo').className.
replace(/\bhide\b/, 'show');
document.getElementById('contractsize').className =
document.getElementById('contractsize').className.
replace(/\bshow\b/, 'hide');
}
break;
case 'intent_tab':
if (direction == 'next')
{
document.getElementById('transportation').className =
document.getElementById('transportation').className.
replace(/\bhide\b/, 'show');
document.getElementById('intent_tab').className =
document.getElementById('intent_tab').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('contractsize').className =
document.getElementById('contractsize').className.
replace(/\bhide\b/, 'show');
document.getElementById('intent_tab').className =
document.getElementById('intent_tab').className.
replace(/\bshow\b/, 'hide');
}
break;
case 'transportation':
if (direction == 'next')
{
document.getElementById('materials').className =
document.getElementById('materials').className.
replace(/\bhide\b/, 'show');
document.getElementById('transportation').className =
document.getElementById('transportation').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('intent_tab').className =
document.getElementById('intent_tab').className.
replace(/\bhide\b/, 'show');
document.getElementById('transportation').className =
document.getElementById('transportation').className.
replace(/\bshow\b/, 'hide');
}
break;
case 'materials':
if (direction == 'next')
{
document.getElementById('type').className =
document.getElementById('type').className.
replace(/\bhide\b/, 'show');
document.getElementById('materials').className =
document.getElementById('materials').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('transportation').className =
document.getElementById('intent_tab').className.
replace(/\bhide\b/, 'show');
document.getElementById('materials').className =
document.getElementById('materials').className.
replace(/\bshow\b/, 'hide');
}
break;
case 'recs':
if (direction == 'next')
{
document.getElementById('fin').className =
document.getElementById('fin').className.
replace(/\bhide\b/, 'show');
document.getElementById('recs').className =
document.getElementById('recs').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('type').className =
document.getElementById('type').className.
replace(/\bhide\b/, 'show');
document.getElementById('recs').className =
document.getElementById('recs').className.
replace(/\bshow\b/, 'hide');
}
break;
case 'fin':
if (direction == 'back')
{
document.getElementById('recs').className =
document.getElementById('recs').className.
replace(/\bhide\b/, 'show');
document.getElementById('fin').className =
document.getElementById('fin').className.
replace(/\bshow\b/, 'hide');
}
break;
}
}
else
{
if (vis == 'type')
{
if (direction == 'next')
{
logic('q_16');
document.getElementById('type').className =
document.getElementById('type').className.
replace(/\bshow\b/, 'hide');
}
else
{
document.getElementById('transportation').className =
document.getElementById('transportation').className.
replace(/\bhide\b/, 'show');
document.getElementById('type').className =
document.getElementById('type').className.
replace(/\bshow\b/, 'hide');
}
}
else if ( vis != 'type')
{
if (vis == 'recs' && direction == 'next')
{
document.getElementById('fin').className =
document.getElementById('fin').className.
replacec(/\bhide\b/, 'show');
document.getElementById('recs').className =
document.getElementById('recs').className.
replace(/\bshow\b/, 'hide');
document.getElementById('calc_risk').className =
document.getElementById('calc_risk').className.
replace(/\bshow\b/, 'hide');
document.getElementById('recs_header').className =
document.getElementById('recs_header').className.
replace(/\bhide\b/, 'show');
}
else if (vis == 'recs' && direction == 'back')
{
document.getElementById('type').className =
document.getElementById('type').className.
replace(/\bhide\b/, 'show');
document.getElementById('recs').className =
document.getElementById('recs').className.
replace(/\bshow\b/, 'hide');
document.getElementById('calc_risk').className =
document.getElementById('calc_risk').className.
replace(/\bhide\b/, 'show');
document.getElementById('recs_header').className =
document.getElementById('recs_header').className.
replace(/\bshow\b/, 'hide');
}
else if (direction == 'next')
{
var tab_array = new Array('mep', 'realestate', 'vendor', 'environmental', 'education', 'construction', 'collaboration', 'consulting', 'clinicalresearch');
var visTab = document.getElementById('vis_tab').value;
for (x = 0; x < tab_array.length; ++x)
{
var temp_tab = tab_array[x];
document.getElementById(temp_tab).className =
document.getElementById(temp_tab).className.
replace(/\bshow\b/, 'hide');
}
switch(visTab)
{
case 'mep':
wholesale();
break;
case 'realestate':
realestate();
break;
case 'vendor':
vendor();
break;
case 'environmental':
environment();
break;
case 'education':
education();
break;
case 'construction':
construction();
break;
case 'collaboration':
collaboration();
break;
case 'consulting':
consulting();
break;
case 'clinicalresearch':
clinicalresearch();
break;
}
document.getElementById('recs').className =
document.getElementById('recs').className.
replace(/\bhide\b/, 'show');
document.getElementById('calc_risk').className =
document.getElementById('calc_risk').className.
replace(/\bshow\b/, 'hide');
document.getElementById('recs_header').className =
document.getElementById('recs_header').className.
replace(/\bhide\b/, 'show');
recsPage();
}
}
else
{
document.getElementById('type').className =
document.getElementById('type').className.
replace(/\bhide\b/, 'show');
//materials realestate vendor environmental education construction collaboration consulting clinicalresearch
var b_vis = new Array('mep', 'realestate', 'vendor', 'environmental', 'education', 'construction', 'collaboration', 'consulting', 'clinicalresearch');
for (x = 0; x < b_vis.length; ++x)
{
var temp_vis = b_vis[x];
document.getElementById(temp_vis).className =
document.getElementById(temp_vis).className.
replace(/\bshow\b/, 'hide');
}
}
}
}
Приведенный выше кодпо большей части будет работать для переключения между различными элементами div, но этот конкретный раздел не работает полностью:
document.getElementById('recs').className =
document.getElementById('recs').className.
replace(/\bhide\b/, 'show');
document.getElementById('calc_risk').className =
document.getElementById('calc_risk').className.
replace(/\bshow\b/, 'hide');
document.getElementById('recs_header').className =
document.getElementById('recs_header').className.
replace(/\bhide\b/, 'show');
recsPage();
recsPage();
никогда не вызывается на локальном хосте.Работает нормально удаленно.Код идентичен между ними.Есть другие разделы в других местах, которые не работают, но сейчас это единственный, который касается меня.
Есть идеи?Поскольку javascript выполняется на стороне клиента, я не могу представить, почему он не работает, когда он не на удаленном сервере.