この JSFiddle を参照してください: http://jsfiddle.net/cDVQP/1/
Chrome と Firefox の両方を使用している場合、Chrome では期待どおりに動作することがわかりますが、Firefox Firebug コンソールでは「TypeError: e is undefined」が表示されます。JSFiddle では、エラーは「TypeError: obj is undefined」と表示されます。
私はこのバグを探し出し、それを理解しようと何時間も費やしましたが、最終的にあきらめてここに来ました。何が原因ですか?
テストする完全なコードは次のとおりです。
<html>
<body>
<div id="x"></div>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script type="text/javascript">
$(document).ready(function(){
getVideos('cats');
});
function getVideos(query){
var url = 'https://www.googleapis.com/youtube/v3/search?part=snippet&maxResults=2&q='+query+'®ionCode=us&type=video&fields=items(id)&key=AIzaSyCCOnozV0lEfnjfMTjpc4TFExAeIGJ6Fh0';
$.ajax({
url: url,
success: function(data){
appendVideos(data);
}
});
}
function appendVideos(data){
// works here
console.log(data);
// but not in $.each
$.each(data.items, function(i, item){
$('#x').append(item.id.videoId + '<br>');
});
}
</script>
</body>
</html>