[英]Can a Tweet Button Be Rendered Explicitly With Javascript Like Google+ Buttons?
Google+允許開發人員利用他們稱之為“顯式呈現”的內容,僅在頁面上發生特定事件時才顯示Google+按鈕(請參閱: http : //code.google.com/apis/+1button/#example-explicit - 渲染 )。 這在需要多個按鈕的頁面上非常有用。
然而,Twitter在頁面上的每個鏈接的位置使用類“twitter-share-button”呈現推文按鈕(使用iframe)。 這會導致非常慢的頁面加載(即使我在加載DOM后異步加載Twitter的widget.js)。
有沒有人知道模仿用於Tweet按鈕的Google+顯式渲染的方法,或僅在發生某個DOM事件時呈現Tweet按鈕的方式(如鼠標懸停)?
你可以使用:
twttr.widgets.load();
我終於找到了辦法。 它不像Google+按鈕那么干凈,但它是:
首先,確保您的文檔頭部中包含jQuery:
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
然后創建一個與最終推文按鈕具有相同URL的鏈接,以及一個用於呈現按鈕的空div:
<a href="http://www.my-site-to-tweet-about.com" id="tlink"></a>
<div id="tbutton"></div>
在頁面底部,在/ body標記的正上方,包括來自Twitter的javascript以及將呈現按鈕的函數,以及在所需事件發生時將激活該函數的偵聽器:
<script type="text/javascript">
//async script, twitter button fashiolista.com style
(function() {
var s = document.createElement('SCRIPT');
var c = document.getElementsByTagName('script')[0];
s.type = 'text/javascript';
s.defer = "defer";
s.async = true;
s.src = 'http://platform.twitter.com/widgets.js';
c.parentNode.insertBefore(s, c);
})();
function renderTweetButton(tbutton,tlink){
var href = $("#"+tlink).attr('href'),
$target = $("#"+tbutton),
qstring = $.param({ url: href, count: "vertical" }),
toinsert = '<iframe allowtransparency="true" frameborder="0" scrolling="no" src="http://platform.twitter.com/widgets/tweet_button.html?'+qstring+'" style="width:57px; height:70px;"></iframe>';
$target.html(toinsert);
}
$("#hoverlink").mouseenter(function() {
renderTweetButton("tbutton","tlink");
});
</script>
最后,根據某些事件添加一個鏈接到您的頁面,該鏈接將激活上面的功能:
<a href="#" id="hoverlink">Hover here to render a tweet button to div#tbutton.</a>
而已。
如果您希望整個測試HTML頁面看到我如何工作,請看這里:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>jQuery Twitter Button Render Test</title>
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
</head>
<body>
<a href="http://www.my-site-to-tweet-about.com" id="tlink"></a>
<div id="tbutton"></div>
<a href="#" id="hoverlink">Hover here to render a tweet button to div#tbutton.</a>
<script type="text/javascript">
//async script, twitter button fashiolista.com style
(function() {
var s = document.createElement('SCRIPT');
var c = document.getElementsByTagName('script')[0];
s.type = 'text/javascript';
s.defer = "defer";
s.async = true;
s.src = 'http://platform.twitter.com/widgets.js';
c.parentNode.insertBefore(s, c);
})();
function renderTweetButton(tbutton,tlink){
var href = $("#"+tlink).attr('href'),
$target = $("#"+tbutton),
qstring = $.param({ url: href, count: "vertical" }),
toinsert = '<iframe allowtransparency="true" frameborder="0" scrolling="no" src="http://platform.twitter.com/widgets/tweet_button.html?'+qstring+'" style="width:57px; height:70px;"></iframe>';
$target.html(toinsert);
}
$("#hoverlink").mouseenter(function() {
renderTweetButton("tbutton","tlink");
});
</script>
</body>
</html>
Sharrre是您正在尋找的。 它支持包括Twitter在內的不少社交網絡。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.