facebook:FB.Canvas.setSize 不起作用
我创建了一个 Facebook 应用程序,它将作为选项卡显示在我公司的粉丝页面上。该应用程序以 951 像素呈现,因此不适合粉丝页面选项卡的默认高度。我读过 facebook 的 js sdk 的可怕文档,并尝试了很多不同的变体 - 所有这些都根本不起作用。这是我当前尝试调整粉丝页面选项卡大小以适合我的应用程序...
<head>
<!-- css / js / meta info here -->
<script type="text/javascript">
window.fbAsyncInit = function() {
FB.Canvas.setSize();
}
function sizeChangeCallback() {
FB.Canvas.setSize();
}
</script>
</head>
<body>
<!-- content goes here -->
<div id="fb-root">
<script type="text/javascript" src="http://connect.facebook.net/en_US/all.js"></script>
<script type="text/javascript">
FB.init({
appId:'xxxxxxxxxx',
status:true,
cookie:true,
xfbml:true,
});
</script>
</div>
</body>
我也尝试过 async init 并使用 setAutoResize() 但没有成功。
感谢您的任何和所有建议... 乙
I have created a facebook app that will be displayed on my companies fan page as a tab. The app renders at 951px so it doesn't fit in the default height of the fan page tab. I've read facebook's horrible documentation for their js sdk and have tried so many different variations - all of them not working at all. Here's my current attempt to resize the fan page tab to fit my app...
<head>
<!-- css / js / meta info here -->
<script type="text/javascript">
window.fbAsyncInit = function() {
FB.Canvas.setSize();
}
function sizeChangeCallback() {
FB.Canvas.setSize();
}
</script>
</head>
<body>
<!-- content goes here -->
<div id="fb-root">
<script type="text/javascript" src="http://connect.facebook.net/en_US/all.js"></script>
<script type="text/javascript">
FB.init({
appId:'xxxxxxxxxx',
status:true,
cookie:true,
xfbml:true,
});
</script>
</div>
</body>
I've also tried async init and using setAutoResize() with no luck.
Thanks for any and all suggestions...
B
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(10)
我刚刚花了一个多小时试图在我的应用程序中解决这个问题,我想提一下您必须遵循的一些基本知识才能使其发挥作用。
没有我的代码中存在错误,但它拒绝工作,因为我在 中包含了 all.js 和我的 JS 代码元素和我的 fb-root div 位于 中。这是我必须将其更改为:
显然,我提到的 3 个元素不必紧邻彼此,但它们必须按此顺序出现在源代码中。这真的让我陷入了困境,所以希望这能为某人节省一些时间和挫败感:)
I just spent over an hour trying to fix this in my app and I wanted to mention a couple of basics that you have to follow for this to work.
There were no errors in my code, but it was refusing to work because I was including all.js and my JS code in the <head> element and my fb-root div was in the <body>. Here's what I had to change it to:
Obviously the 3 elements I mentioned don't have to be right after each other, but they do have to show up in this order in your source code. This really threw me for a loop so hopefully this will save someone some time and frustration :)
如果 Facebook 可以计算页面的高度,通常就可以了。但是,如果您有响应式设计,这是不可能的。
我正在使用一个 hack,它使用 jQuery 来计算包装器 div 的高度,然后显式设置它:
这应该放在您的 FB.init() 方法中。
It usually works if Facebook can calculate the height of your page. However if you have a responsive design this is not possible.
I am using a hack that does the job using jQuery to calculate the height of the wrapper div and then explicitly set it:
This should go in your FB.init() method.
如果由于某种原因设置了 window.name ,则 FB.setAutoSize 将无法工作, http:// /bugs.developers.facebook.net/show_bug.cgi?id=19720
就我而言,它以某种方式连接到 jquery $.data
if for some reason window.name is set the FB.setAutoSize wont work, http://bugs.developers.facebook.net/show_bug.cgi?id=19720
in my case its connected somehow to jquery $.data
我找到了使用 jQuery 和 FB.setSize() 时修复问题的解决方案 - 如果您在 $(function(){}) 之前设置变量定义(jQuery DOM 就绪) - setSize 不起作用。如果所有变量定义都位于 $(function(){ all vars HERE }) 内 - setSize 开始工作!
I'm found the solution for fix issues when using jQuery and FB.setSize() - if you set vars definition before $(function(){}) (jQuery DOM ready) - setSize doesn't work. If all vars definition located inside $(function(){ all vars HERE }) - setSize starts working!
您可能需要等待图像加载。否则,
FB.Canvas.setSize();
可能会触发得太快并且不包含图像大小。使用 jQuery:
You might need to wait for images to be loaded. Otherwise the
FB.Canvas.setSize();
might fire too soon and not include image sizes.With jQuery use:
如果您的应用程序的内容站点具有不同的高度,找到了再次降低高度的解决方案。通常,高度很容易增加,但不会再次降低到较小的位置。
Found a solution to reduce the height again if the content sites of your App have different heights. Usually the height increases easily but doesn't decrease to a smaller site again.
这就是我初始化 Facebook 应用程序的方式:
This is how I initialise my facebook applications:
这是我使用的:
here is what I use:
我还注意到,如果用户的“安全浏览”设置被禁用,setSize 调用就会失败。对于大多数人来说这可能不是问题,因为默认情况下启用该设置,但如果您遇到此问题并且现在头几乎秃了(就像我一样),请在您正在测试的帐户上检查此设置和。
I also noticed the setSize call fails if the user's "Secure Browsing" setting is disabled. This may not be an issue for most, since the setting is enabled by default, but if you're running into this issue and now have an almost-bald head (like I do), check this setting on the account you're testing with.