Как выполнить скрипт после того, как пользователь нажмет кнопку «Нравится» на кнопке «Нравится» в Facebook? - PullRequest
4 голосов
/ 25 мая 2011

Я пытаюсь использовать кнопку «Мне нравится» в Facebook через iFrame, например:

<iframe id="test" src="http://www.facebook.com/plugins/like.php? 
       href=http://yoururl.com/&amp;
       layout=button_count&amp;
       show_faces=false&amp;
       width=50&amp;
       action=like&amp;
       colorscheme=light&amp;
       height=21" 
       scrolling="no" frameborder="0" 
       style="border:none; overflow:hidden; width:50px;  
              height:21px;" 
       allowTransparency="true">

После того, как пользователь впервые нажимает «Мне нравится», я хочу выполнить Javascript в моем DOM-контенте.,Как бы я поступил так?

1 Ответ

5 голосов
/ 25 мая 2011

Вы имеете в виду, что хотите выполнить Javascript, когда вам что-то понравится?

Для этого вы можете использовать Javascript SDK Facebook, особенно событие edge.create.
См

  1. http://developers.facebook.com/docs/reference/javascript/ (для общего документа SDK)
  2. http://developers.facebook.com/docs/reference/javascript/FB.Event.subscribe/ (для документа события)

Это должно работать и с IFrame-версией. Если нет, вам нужно переключиться на кнопку, похожую на XFBML. Это определенно работает с версией XFBML.

Пример:

<!-- Load the SDK (or even better, load it asynchronously. See first link above -->
<div id="fb-root"></div>
<script src="http://connect.facebook.net/en_US/all.js"></script>
<script>
// initalize your Facebook App
  FB.init({
    appId  : 'YOUR APP ID',
    status : true, // check login status
    cookie : true, // enable cookies to allow the server to access the session
    xfbml  : true  // parse XFBML
  });
// subscribe to the event
FB.Event.subscribe('edge.create', function(response) {
  alert('you liked this');
});
FB.Event.subscribe('edge.remove', function(response) {
  alert('you unliked this');
});
</script>
<!--
    The XFBML Like Button, if the iframe version doesn't work (not 100% sure)
    <fb:like></fb:like>
 -->
...