このコードを「意図したとおりに」機能させるには、どのようなルートを取るべきか疑問に思っています。API呼び出しは非同期であるため、コンストラクターはデータが読み込まれる前に戻ります。
addSongById: function (songId) {
var song = new Song(songId);
console.log(song);
this.addSong(song);
if (this.songCount() == 1)
this.play();
UserInterface.refresh();
SongGrid.reload();
},
function Song(songId) {
$.getJSON('http://gdata.youtube.com/feeds/api/videos/' + songId + '?v=2&alt=json-in-script&callback=?', function (data) {
this.id = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function (c) { var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8); return v.toString(16); });
this.songId = songId;
this.url = "http://youtu.be/" + songId;
this.name = data.entry.title.$t;
});
}
コンストラクターが時期尚早に戻らないように強制することは可能ですか?理想的には、Songコンストラクターに任意の量のパラメーターを渡して、Songにのみ関連する情報をその範囲外に持ち込む必要はありません。