사용자의 최근 트랙 대신 사용자가 좋아하는 아티스트를 표시하도록 this 스크립트를 사용자 정의하려고합니다.jQuery + get.JSON + Last.FM 문제
이것은 내가 생각해 낸 것이지만 전혀 작동하지 않습니다. 피드의 속성을 쉽게 변경한다고 생각했지만 분명히 그렇지 않습니다.
(function($){
$.fn.lastFM = function(options) {
var defaults = {
number: 10,
username: 'willblackmore',
apikey: '96e0589327a3f120074f74dbc8ec6443',
artSize: 'medium',
noart: 'images/noartwork.gif',
onComplete: function(){}
},
settings = $.extend({}, defaults, options);
var lastUrl = 'http://ws.audioscrobbler.com/2.0/?method=user.gettopartists&user='+settings.username+'&api_key='+settings.apikey+'+'&limit='+settings.number+'&format=json&callback=?';
var $this = $(this);
var container = $this.html();
$this.children(':first').remove();
if(settings.artSize == 'small'){imgSize = 0}
if(settings.artSize == 'medium'){imgSize = 1}
if(settings.artSize == 'large'){imgSize = 2}
this.each(function() {
$.getJSON(lastUrl, function(data){
$.each(data.topartists.artist, function(i, item){
if(item.image[1]['#text'] == ''){
art = settings.noart;
}else{
art = stripslashes(item.image[imgSize]['#text']);
}
url = stripslashes(item.url);
song = item.name;
artist = item.playcount['#text'];
album = item.streamable['#text'];
$this.append(container);
var $current = $this.children(':eq('+i+')');
$current.find('[class=lfm_song]').append(song);
$current.find('[class=lfm_artist]').append(artist);
$current.find('[class=lfm_album]').append(album);
$current.find('[class=lfm_art]').append("<img src='"+art+"' alt='Artwork for "+album+"'/>");
$current.find('a').attr('href', url).attr('title', 'Listen to '+song+' on Last.FM').attr('target', '_blank');
//callback
if(i==(settings.number-1)){
settings.onComplete.call(this);
}
});
});
});
};
//Clean up the URL's
function stripslashes(str) {
return (str+'').replace(/\0/g, '0').replace(/\\([\\'"])/g, '$1');
}
})(jQuery);`
아이디어가 있으십니까? 감사.
api 키를 게시 하시겠습니까? – g33kz0r