Не отображаются лайки при использовании ajax
Тем кто понимает проблему и хочет по-быстрому ее решить, советую перейти к части как решить?. Остальным немного лирики.
Практически на всех проектах мы используем стандартный набор социальных кнопок: vk-like, facebook-like, g+, tweet. И код для всего это тоже используется стандартный.
Добавляется в head вот такой код
<!-- G+ -->
<script type="text/javascript" src="https://apis.google.com/js/plusone.js"></script>
<!-- FB -->
<script type="text/javascript" src="http://userapi.com/js/api/openapi.js?34"></script>
<!-- VK -->
<script type="text/javascript">
VK.init({apiId: your_API_ID, onlyWidgets: true});
</script>
А в место? где надо отобразить социальные кнопки, вставляется примерно такой код:
<div class="b_likes">
<div class="like_itm">
<?php
$pageURL = get_permalink();
echo '<iframe src="http://www.facebook.com/plugins/like.php?href='.$pageURL.
'&send=false&layout=button_count&width=110&show_faces=true&action=like
&colorscheme=light&font&height=21" scrolling="no" frameborder="0"
style="border:none; overflow:hidden; width:140px; height:21px;"
allowTransparency="true"></iframe>';
?>
</div>
<div class="like_itm"><a href="http://twitter.com/share"
class="twitter-share-button" data-count="horizontal">Tweet</a>
<script type="text/javascript" src="http://platform.twitter.com/widgets.js">
</script>
</div>
<divclass="like_itm">
<g:plusone size="medium"></g:plusone></div>
<divclass="like_itm">
<div id="vk_like-<?php the_ID(); ?>"></div>
<script type="text/javascript">
VK.Widgets.Like(
"vk_like-<?php the_ID(); ?>"
, {type: "button"}
, <?php the_ID(); ?>
);
</script>
</div>
</div>
Как дошли до жизни такой
Последние веяния интернет технологий говорят нам, что ajax очень круто и для пользователей крайне необходимо. С этим можно согласить или не согласиться, но необратить на эту штуку внимания нельзя. Поскольку sawtech прогрессивная контора, то и нас не миновала чаша сия. И вот мы сделали ajax-подгрузку постов в одном из проектов. Чтобы конечный продукт хорошо продвигался добавили сразу же для каждой записи социальные кнопки и обнаружили, что по какой-то причине не все лайки, загружаемые с помощью axaj хотят отображаться корректно.
Проблема в том, что инициация кнопок происходит скриптом, который отрабатывает в момент создания документа, а подгружаемые элементы вставляются уже после.
Как решить?
А решается не сложнее начальной инициации. Для всех кнопок существуют методы повтороной инициации. Для этого надо добавить небольшое кусочки кода рядом с кодом самой кнопки.
<!-- Для твиттера -->
<script type="text/javascript">
!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0],
p=/^http:/.test(d.location)?'http':'https';
if(!d.getElementById(id)){js=d.createElement(s);
js.id=id;js.src=p+'://platform.twitter.com/widgets.js';
fjs.parentNode.insertBefore(js,fjs);}}
(document, 'script', 'twitter-wjs');
twttr.widgets.load();
</script>
<!-- Для G+ -->
<script type="text/javascript">gapi.plusone.go();</script>
<!-- Для FB, если используете XFBML вариант -->
<script type="text/javascript">FB.XFBML.parse();</script>
Я использую iframe загрузку fk-like, поэтому у меня все было нормально с fb изначально, а контакт сам шарит и все обрабатывает без дополнительных тычков.
В итоге, лично я получил вот такой код:
<div class="b_likes">
<?php $like_url = urlencode( get_permalink() ); ?>
<div class="like_itm">
<?php
$pageURL = get_permalink();
echo '<iframe src="http://www.facebook.com/plugins/like.php?href='.$pageURL.
'&send=false&layout=button_count&width=110&show_faces=true&action=like
&colorscheme=light&font&height=21" scrolling="no" frameborder="0"
style="border:none; overflow:hidden; width:140px; height:21px;"
allowTransparency="true"></iframe>';
?>
</div>
<div class="like_itm">
<a href="https://twitter.com/share" class="twitter-share-button"
data-url="<?php echo $like_url; ?>" data-text="<?php the_title(); ?>
<?php the_permalink(); ?> ">Tweet</a>
<script type="text/javascript">
!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0],
p=/^http:/.test(d.location)?'http':'https';
if(!d.getElementById(id)){js=d.createElement(s);
js.id=id;js.src=p+'://platform.twitter.com/widgets.js';
fjs.parentNode.insertBefore(js,fjs);}}
(document, 'script', 'twitter-wjs');
twttr.widgets.load();
</script>
</div>
<div class="like_itm">
<div class="g-plusone" data-size="medium"
data-href="<?php echo $like_url; ?>"></div>
<script type="text/javascript">gapi.plusone.go();</script>
</div>
<div class="like_itm">
<div id="vk_like-<?php the_ID(); ?>"></div>
<script type="text/javascript">
VK.Widgets.Like("vk_like-<?php the_ID(); ?>", {
type: "button"
, pageUrl: '<?php echo $like_url; ?>'
}, <?php the_ID(); ?> );
</script>
</div>
</div>
Теперь все работает корректно. Как я и обещал, ничего сложного.