有没有一种相对干净的方法可以让我获得 twitter 按钮的简单 javascript 版本的所有内置优点,但推迟执行其相当繁重的 javascript,直到用户真正点击按钮?
我在想我可以像这样构建一个锚标签:
<a class="twitter-share-button"
onclick="clicked_twitter_button(this);"
data-url="http://www.mysite.com"
data-count="none"
>
<img src="twitter_button.gif" />
</a>
然后定义一个函数,如:(注意:编辑原始帖子,现在设置href):
function clicked_twitter_button( anchor_instance ) {
// The line below is specified by twitter.
!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0];if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src="https://platform.twitter.com/widgets.js";fjs.parentNode.insertBefore(js,fjs);}}(document,"script","twitter-wjs");
anchor_instance.href = "https://twitter.com/share";
// Do something to mimic click of < anchor_instance >
}
如果我twitter_button.gif
看起来与 twitter 指定的 javascript 通常插入的图像完全一样,那么 twitter 指定的 javascript 的执行对用户来说基本上看起来就像一个无操作。这应该很容易做到(假设 Twitter 的图像在所有平台上都是相同的)。
因此,希望我唯一需要帮助的是弄清楚如何anchor_instance
在 Twitter 的 javascript 执行后模拟点击。
我的目标是保留 javascript twitter 按钮提供的漂亮弹出窗口(和默认值)。
谢谢你。