将点击事件绑定到Google自定义搜索结果

时间:2014-08-08 16:35:27

标签: jquery google-custom-search

我正在使用Google自定义搜索来获取搜索查询的结果。结果很好。我现在需要捕获生成结果的click事件。
到目前为止,我已尝试过以下内容:

<script>
    (function () {
        window.__gcse = {
            callback: myCallback
        };

        function myCallback() {
            $('input.gsc-input').keyup(function (e) { if (e.keyCode == 13 || e.which == 13) { console.log('enter pressed'); } });
            $('input.gsc-search-button').on('click', function (e) { console.log('clicked'); });
            $('a').on('click', function (e) {
                alert();
                e.preventDefault();
                e.stopPropagation();
                debugger;
                var obj = $(this);
            });
        }

        var cx = 'my-gcse-id';
        var gcse = document.createElement('script');
        gcse.type = 'text/javascript';
        gcse.async = true;
        gcse.src = (document.location.protocol == 'https:' ? 'https:' : 'http:') +
            '//www.google.com/cse/cse.js?cx=' + cx;
        var s = document.getElementsByTagName('script')[0];
        s.parentNode.insertBefore(gcse, s);
    })();


</script>

<gcse:search linktarget="_parent" enableAutoComplete="true"></gcse:search>

上面给出了控制台日志,单击输入搜索框和按钮,但不是单击搜索结果中的链接。 我也尝试过window.load和document.ready但是无法正常工作。

<script>
    $(window).on("load", function () {

        $('#gsc-i-id1').css('background', '');
        $('#gsc-i-id1').on("blur", function (e) {

            $(this).css('background', '');
        });
        $("a").on("click", function (e) {
            alert();
            e.preventDefault();
            debugger;
            var obj = $(this);
        });
    });
    $(document).ready(function () {

        $('#gsc-i-id1').css('background', '');
        $("a").on("click", function (e) {
            e.preventDefault();
            debugger;
            var obj = $(this);
        });
    });
  </script>

任何一位专家都可以帮助我实现这一目标。

1 个答案:

答案 0 :(得分:0)

你的代码只为我工作,,, !!您需要做的就是在a.clicked上添加对alert()的调用 这意味着在您的代码中找到以下代码段

$(window).on("load", function () {

    $('#gsc-i-id1').css('background', '');
    $('#gsc-i-id1').on("blur", function (e) {

        $(this).css('background', '');
    });
    $("a").on("click", function (e) {
        alert();
        e.preventDefault();
        debugger;
        var obj = $(this);
    });
});

并将其替换为

      $(window).on("load", function () {

        $("a").on("click", function (e) {
            alert();
            e.preventDefault();
            debugger;
            var obj = $(this);
        });
    });

我必须提到我不使用默认的谷歌自定义搜索模板我已经使用两列模板制作了自己的搜索框,所以在我的情况下,窗口永远不会变模糊,我很确定你一定想通了现在这个虽然..loll

使用ti之后,我意识到它适用于没有广告的结果页面。如果你有包含广告的网页,当你点击广告时...广告文字就在一个范围内,这就是为什么a.onclick事件不能阻止违规行为