我有一个链接(在 Font Awesome 图标上),如下所示:
<a href="https://twitter.com/intent/tweet?text=Some text about this link&url=http://some.site.co/wow/greatamp;via=toby1kenobi">
<span class="fa fa-twitter-square"></span>
</a>
我在此页面上的“有限依赖项”下使用 Javascript 片段,这就在链接之后。这是页面上唯一的网络意图。
如果我单击链接,Twitter 弹出窗口将打开,原始页面导航到弹出窗口中显示的相同内容。
我无法弄清楚我做错了什么 - 如果我将另一个事件附加到链接并调用 preventDefault(),这将停止重复,但我认为这不应该是必要的。
编辑 这是 Twitter 的代码:
(function() {
if (window.__twitterIntentHandler) return;
var intentRegex = /twitter\.com(\:\d{2,4})?\/intent\/(\w+)/,
windowOptions = 'scrollbars=yes,resizable=yes,toolbar=no,location=yes',
width = 550,
height = 420,
winHeight = screen.height,
winWidth = screen.width;
function handleIntent(e) {
e = e || window.event;
var target = e.target || e.srcElement,
m, left, top;
while (target && target.nodeName.toLowerCase() !== 'a') {
target = target.parentNode;
}
if (target && target.nodeName.toLowerCase() === 'a' && target.href) {
m = target.href.match(intentRegex);
if (m) {
left = Math.round((winWidth / 2) - (width / 2));
top = 0;
if (winHeight > height) {
top = Math.round((winHeight / 2) - (height / 2));
}
window.open(target.href, 'intent', windowOptions + ',width=' + width +
',height=' + height + ',left=' + left + ',top=' + top);
e.returnValue = false;
e.preventDefault && e.preventDefault();
}
}
}
if (document.addEventListener) {
document.addEventListener('click', handleIntent, false);
} else if (document.attachEvent) {
document.attachEvent('onclick', handleIntent);
}
window.__twitterIntentHandler = true;
}());
它绑定到文档的点击事件(而不是任何锚点),我不明白为什么它不取消默认导航。它似乎击中了“e.preventDefault && e.preventDefault();” 行好。