Facebook JavaScript SDK FB.Canvas.Setsize und SetAutogrow funktioniert nicht in IE7/8
Frage
Derzeit teste ich eine Facebook -Registerkartenseite. Ich verwende das JavaScript SDK mit der empfohlenen Async Init -Methode:
window.fbAsyncInit = function() {
FB.init({
appId : app_id,
status : true,
cookie : true,
oauth : true,
xfbml : true
});
FB.getLoginStatus( loginStatus );
FB.Canvas.setAutoGrow( );
FB.Canvas.setSize( {height: 1200 });
};
(function(d){
var js, id = 'facebook-jssdk'; if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
d.getElementsByTagName('head')[0].appendChild(js);
}(document));
Ich habe Probleme in IE7/8 bei dem die setAUTOGROW und SetSize reagieren nicht. Meine Registerkartenseite ist NICHT Größe auf den vollständigen Inhalt überhaupt. Stattdessen erhalte ich in der IE -Konsole diesen Fehler, wenn ich entweder setAutogrow oder setSize aufrufe:
SCRIPT438: Object doesn't support this property or method all.js, line 15 character 3916
Ich habe dies in Chrome/FF/IE9 PC/MAC getestet und alle funktionieren gut, nur IE7/8 geben mir diese Probleme. Weiß jemand, ob es sich um bekannte Fehler mit JS SDK von FB oder mache ich etwas falsch?
Lösung
<script type="text/javascript">
FB.Canvas.setSize({ width: 520, height: 1400 });
window.fbAsyncInit = function () {
FB.Canvas.setAutoResize();
}
</script>
Verwenden Sie dies und setzen Sie es direkt vor dem Schließen des Body -Tags.
Stellen Sie außerdem sicher, dass Sie dieses Markup auch in den Körper Tags haben:
<div id="fb-root"></div>
<script type="text/javascript" src="//connect.facebook.net/en_US/all.js"></script>