Im пытается добавить некоторые данные в формате JSON с last.fm API,getElementById(). AppendChild() отказывается работать!
я использую сигнал() в несколько этапов, чтобы проверить API в настоящее время анализируется правильно, и это,
Это привело меня . к выводу, что getElementById() AppendChild() не работает, ниже является URL для тестовой страницы я настроил:
http://mutant-tractor.com/tabtest.html
Код здесь
function calculateDateAgo(secAgo) {
var agoString, agoRange, agoScaled;
if(secAgo >= (agoRange = 60*60*24))
agoString = (agoScaled = Math.floor(secAgo/agoRange))+" "+(agoScaled>1?"days":"day") + " ago"
else if(secAgo >= (agoRange = 60*60))
agoString = (agoScaled = Math.floor(secAgo/agoRange))+" "+(agoScaled>1?"hours":"hour") + " ago"
else if(secAgo >= (agoRange = 60))
agoString = (agoScaled = Math.floor(secAgo/agoRange))+" "+(agoScaled>1?"minutes":"minute") + " ago"
else if(secAgo >= -60)
agoString = "blastin' out now";
else
agoString = "soon ;)";
return agoString
}
function truncateName(name, l) {
return name.length > l ? name.substr(0,l-2) + "\u2026" : name
}
function lfmRecentTracks(JSONdata) {
try {
var eImg, eLink, eSpan, divTag, eWrapper;
var oTracks = new Array().concat(JSONdata.recenttracks.track);
for (var i = 0; i [lessthanhere] oTracks.length; i++) {
//insert track link
spanTag = document.createElement("span");
spanTag.className = "lfmTrackInfoCell tabslider";
eLink = document.createElement("a");
eLink.appendChild(document.createTextNode(truncateName(oTracks[i].name, 25)));
//alert(truncateName(oTracks[i].name, 25));
spanTag.appendChild(eLink);
eLink.href = oTracks[i].url;
//alert(oTracks[i].url);
eLink.target = "new";
eLink.className = "lfmTrackTitle";
document.body.appendChild(spanTag);
//insert artist name
eSpan = document.createElement("span");
eSpan.appendChild(document.createTextNode(truncateName(oTracks[i].artist["#text"], 22)));
//alert(truncateName(oTracks[i].artist["#text"], 22));
eSpan.className = "lfmTrackArtist";
document.body.appendChild(eSpan);
//insert date
eSpan = document.createElement("span");
spanTag.appendChild(eSpan);
eSpan.appendChild(document.createTextNode( (typeof oTracks[i].date=="undefined"?"now playing":calculateDateAgo(new Date().getTime()/1000 - oTracks[i].date.uts)) ));
//alert((typeof oTracks[i].date=="undefined"?"now playing":calculateDateAgo(new Date().getTime()/1000 - oTracks[i].date.uts)));
eSpan.className = "lfmTrackDate";
document.body.appendChild(eSpan);
}
} catch(e) {}
}
Единственный способ это работает с помощью document.body.appendChild()
Я звоню сценарий в голове, если это имеет значение?
ДИВ Я пытаюсь прикрепить их к 4 различных дивы то есть в течение цикла каждый цикл должен ссылаться на другой элемент,
Заранее спасибо! Myles
Я не вижу getElementById в коде здесь, но я абсолютно уверен, что он работает. – annakata
Как вы воспроизводите ошибку на тестовой странице? –
Создание элементов DOM в прямом кодексе очень подвержено ошибкам. Вы могли бы изучить шаблоны двигателей. http://api.jquery.com/category/plugins/templates/ или http://code.google.com/closure/templates/docs/helloworld_js.html –