我正在实施一个Facebook应用程序,该应用程序显示为粉丝页面中的标签。
该应用程序有一个产品详细信息页面,其中包含like,send和comments插件。
问题是当点击发送和喜欢按钮时,弹出对话框(点击按钮后弹出的窗口)被iframe的左边缘剪切(应用程序是从右到左的语言)。
从图形设计的角度来看,按钮的位置无法更改,也不允许滚动条。应用程序必须是520px宽,不多也不少。
是否有任何选项可以控制弹出窗口的位置以防止其剪裁?还有其他方法可以防止剪辑吗?
我在这里搜索了类似的问题但没有成功。
答案 0 :(得分:6)
由于这些按钮在页面中包含HTML结构,因此可以通过CSS进行样式设置。因此,您可以使用CSS移动弹出对话框。
如果你仔细看看facebook提供的弹出窗口,你会发现它附带了一些样式:
您现在唯一需要做的就是通过CSS将此弹出窗口移动到正确的位置。
例如:如果你想完全隐藏like按钮的注释弹出窗口,你可以使用这个CSS:
.fb_edge_comment_widget.fb_iframe_widget {
display: none;
}
如果您现在想要移动它,则无法使用.fb_edge_comment_widget.fb_iframe_widget
,因为元素属性(由JavaScript设置)将覆盖您的CSS。你必须使用低一个元素:
.fb_edge_comment_widget.fb_iframe_widget > span{
right: 300px;
}
此代码将弹出窗口向左移动300px:
这不是最美丽的解决方案(注意框顶部的小箭头现在什么都没有),但是它有效。
<!DOCTYPE html>
<html>
<head>
<title>Test</title>
<style type="text/css">
.fb_edge_comment_widget.fb_iframe_widget > span{
right: 300px;
}
#wrap {
width: 650px;
margin: 0 auto;
}
</style>
</head>
<body>
<div id="wrap">
<div id="fb-root"></div>
<script>(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/de_DE/all.js#xfbml=1&appId=336384849737745";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));</script>
<div class="fb-like" data-href="http://www.google.de" data-send="true" data-width="500" data-show-faces="false"></div>
</div>
</body>
</html>
答案 1 :(得分:0)
这不是你问题的确切答案。看来你根本无法控制弹出窗口。我很高兴通过将我的fb按钮代码放在一个仅与按钮一样高的div并设置overflow:hidden来完全摆脱弹出窗口。然后弹出窗口根本不可见。
<div class="fb-wrap">
<div class="fb-like" data-href="http://www.facebook.com/YOURURL="false" data-width="200" data-show-faces="false" data-colorscheme="dark"></div></div>
<style>
.fb-wrap {
height: 36px;
overflow: hidden;
}
</style>