检查浏览器是否有Pinterest Pin it按钮

时间:2015-10-23 15:07:24

标签: javascript jquery google-chrome google-chrome-extension pinterest

我编写了一个脚本,为我网站上的大多数图片添加Pinterest按钮。问题是当某人在浏览器中启用Chrome Pin it extension时,"将其固定为"按钮为用户显示两次。

无论如何,在JavaScript中,检查用户是否在浏览器中启用了此扩展程序?

(function($) {

    $(function() {

      $('.container img').each(function() {
          if ($(this).parent('a')) {
              var $permalink = $(this).parent('a').attr('href');
          }
          else {
              var $permalink = $(location).attr('href');
          }


          var $permalink = $(location).attr('href'),
              $title = $('h1.product_name').text() || $('h2.header');

          var $linkhtml = $('<a/>', {
              'class':'pin-it-button pinme',
              'html': '<img src="//assets.pinterest.com/images/pidgets/pinit_fg_en_rect_gray_20.png" />',
              'count-layout': 'horizontal',
            'style': 'cursor:pointer; position:absolute; bottom:30px; left:0; border:0 none; opacity: 0.4;',
              'href': 'http://pinterest.com/pin/create/button/?url=' + $permalink  + '&media=' + $(this).attr('src') + '&description=' + $title
          });

          if ($(this).parent('a')) {
              $(this).addClass('pinme').parent('a').after($linkhtml);
          }
          else {
              $(this).addClass('pinme').after($linkhtml);
          }

          $('.pinme').hover(
            function() {
              if ($(this).hasClass('pin-it-button')) {
                console.log('hello');
                  $(this).css('opacity', '1');
              }
              else {
                  $(this).parent().siblings('.pin-it-button').css('opacity', '1');
              }
            }, function() {
              if ($(this).hasClass('pin-it-button')) {
                  $(this).css('opacity', '0.4');
              }
              else {
                  $(this).parent().siblings('.pin-it-button').css('opacity', '0.4');
              }
            }
          );


      });
    });
})(jQuery);

2 个答案:

答案 0 :(得分:10)

新的Pinterest扩展(2017)

直接在<span>

下注入<body悬停按钮
<span style="border-radius: 3px;
    text-indent: 20px;
    width: auto;
    padding: 0px 4px 0px 0px;
    text-align: center;
    font-style: normal;
    font-variant: normal;
    font-weight: bold;
    font-stretch: normal;
    font-size: 11px;
    line-height: 20px;
    font-family: &quot;Helvetica Neue&quot;, Helvetica, sans-serif;
    color: rgb(255, 255, 255);
    background: url(&quot;&quot;) 3px 50% / 14px 14px no-repeat rgb(189, 8, 28);
    position: absolute;
    opacity: 1;
    z-index: 8675309;
    display: none;
    cursor: pointer;
    border: none;
    -webkit-font-smoothing: antialiased;
    top: 240px;
    left: 110px;
">Save</span>

所以一个简单的检查就是:

var pin = document.querySelector('body > span[style*="8675309"][style*="rgb(189, 8, 28)"]')

或者您可以检查包含P徽标的整个背景base64字符串。

旧PinIt扩展的旧答案:

检查安装了Pin It扩展程序的页面,我们可以看到它将自己的属性添加到<body>

<body data-pinterest-extension-installed="cr1.39.1">

在js中很容易确定属性的存在:

if (document.body.dataset.pinterestExtensionInstalled) {
    console.log("Pin It extension detected!");
}

请注意,该属性是在加载页面后添加的,因此您无法在DOMContentLoaded事件处理程序中进行检查;暂停setInterval或使用MutationObserver

  • 包含"run_at": "document_end""document_idle"的内容脚本(默认模式):

    var PinItInstalled = undefined;
    
    new MutationObserver(function(mutations) {
        PinItInstalled = document.body.dataset.pinterestExtensionInstalled;
        this.disconnect();
    }).observe(document.body, {
        attributes: true,
        attributeFilter: ["data-pinterest-extension-installed"]
    });
    
  • 包含"run_at": "document_start"的内容脚本:

    var PinItInstalled = undefined;
    
    document.addEventListener("DOMContentLoaded", function() {
        new MutationObserver(function(mutations) {
            PinItInstalled = document.body.dataset.pinterestExtensionInstalled;
            this.disconnect();
        }).observe(document.body, {
            attributes: true,
            attributeFilter: ["data-pinterest-extension-installed"]
        });
    });
    

P.S。不要忘记测试如果Pin It扩展程序在悬停时显示其按钮的选项被禁用会发生什么。

答案 1 :(得分:2)

虽然检测页面上存在扩展名或pinit.js可能是值得的,但更简单的解决方案是简单地将data-pin-no-hover属性添加到图像中。这将告诉扩展程序忽略图像。

<img src="whatevz" data-pin-no-hover="true" />

如果设置了data-pin属性,确实没有理由关心它是否已安装。

另一个选择是不创建自己的悬停按钮,但使用pinit.js为您创建悬停按钮。请参阅the docs

<script
  type="text/javascript"
  async defer
  data-pin-hover="true"
  src="//assets.pinterest.com/js/pinit.js"
></script>