我如何确认发送了Twitter网络意图?

时间:2014-04-24 20:18:58

标签: twitter webintents

点击Twitter Web Intent后,我想确认用户是否发了推文。我怎么能做到这一点?

示例:

<a href="https://twitter.com/intent/tweet?text=Simple+Web+Intent">Tweet</a>

假设匿名*用户点击此链接和推文,我该如何确认?

理想情况下,我希望获得推文的链接。


* anonymous在我的网站上未经过身份验证且未知道他们的Twitter用户名

3 个答案:

答案 0 :(得分:6)

<强>更新

在Twitter更新小部件的行为后,此解决方案不再有效。您只能跟踪现在是否点击了推文按钮,而不是实际发布了推文。


您可以使用&#39; twttr.events.bind&#39;跟踪推文。事件监听器构成Twitter API。可以在此处找到跟踪推文的工作示例:http://jsfiddle.net/EZ4wu/3/

<强> HTML

<a href="https://twitter.com/intent/tweet?url=https://www.webniraj.com/2012/09/11/twitter-api-tweet-button-callbacks/&text=Twitter+API:+Tweet+Button+Callbacks"><i class="icon-twitter-sign icon-white"></i> Tweet</a>

<强>的JavaScript

function reward_user( event ) {
    if ( event ) {
        alert( 'Tweeted' );
        console.log( event );
    }
}

window.twttr = (function (d,s,id) {
    var t, js, fjs = d.getElementsByTagName(s)[0];
    if (d.getElementById(id)) return; js=d.createElement(s); js.id=id;
    js.src="//platform.twitter.com/widgets.js"; fjs.parentNode.insertBefore(js, fjs);
    return window.twttr || (t = { _e: [], ready: function(f){ t._e.push(f) } });
    }(document, "script", "twitter-wjs"));

twttr.ready(function (twttr) {
    twttr.events.bind('tweet', reward_user);
});

我的previous solution现已过时,似乎无法正常工作。

答案 1 :(得分:0)

试试这个:

                        twttr.events.bind('loaded', function(event) {

                            window.location = "http://theredirect_link.com"

                        });

答案 2 :(得分:0)

@ Niroj的回答不再适用。他们更新了api,因此事件监听器会在用户单击按钮后立即触发 - 您无法检查他是否实际发推文。

如果您自己创建窗口(不使用Twitter小部件),您至少可以检测窗口是否已关闭(用户关闭窗口或推文)。

不要链接小部件api!

HTML:

<a id="twitter-intent" href="https://twitter.com/intent/tweet?url=https://www.webniraj.com/2012/09/11/twitter-api-tweet-button-callbacks/&text=Twitter+API:+Tweet+Button+Callbacks"><i class="icon-twitter-sign icon-white"></i> Tweet</a>

JS:

document.getElementById('twitter-intent').addEventListener('click', function(e) {

    e.preventDefault();
    e.stopPropagation(); //this should do in case you don't want to unlink twitter widgets api

    var width  = 575,
        height = 400,
        left   = (screen.width  - width)  / 2,
        top    = (screen.height - height) / 2,
        url    = this.href,
        opts   = 'status=1' +
                 ',width='  + width  +
                 ',height=' + height +
                 ',top='    + top    +
                 ',left='   + left;

    var win = window.open(url, 'twitter_share', opts);

    var timer = setInterval(checkWin, 500);

    function checkWin() {

        if (win.closed) {
            //just assume the user tweeted (he could just close the window without tweeting)
            alert("Thank you for tweeting!");   
            clearInterval(timer);

        }

    }

});