0

我一直在拔头发试图弄清楚这一点。希望有人可以帮忙。

我正在尝试内容锁定此站点:blog.funnyhunt.com

这个想法是,当有人单击“喜欢”按钮(效果很好)然后显示内容时,人们应该喜欢我的 Facebook 页面……但最后一点不起作用。

现在这是奇怪的部分......对于某些人来说它可以正常工作,而对于其他人来说它不会显示内容它只是让他们喜欢页面并且内容保持锁定状态。

我已经用一系列不同的储物柜对此进行了测试,并且我一直获得相同的体验,有时它有效,有时则无效。

那么发生了什么??我已经尝试使用不同的 Facebook 帐户、代理和清除 cookie 来测试它......但没有运气。

4

2 回答 2

0

我用 JavaScript 开发了一个内容储物柜,具有以下功能:

  • SEO(搜索引擎优化):因为我们希望搜索引擎能够读取内容并对其进行索引,所以我们将它们隐藏起来。
  • 标准社交小部件:我们会将这些内容锁定功能添加到 Facebook、Twitter、Google+ 和 LinkedIn 原生源代码中。
  • 软行为:由于我们不想打扰我们的忠实读者,一旦内容被解锁,解​​锁将影响网站上所有被屏蔽的内容。
  • 源代码是 JavaScript,因此可以将它集成到每个网页上(我们将只使用 jQuery 来实现视觉效果)。

该实现类似于上面引用的工具之一,即使用 cookie。

这是代码,如果您想查看它的实际效果或它与更多社交小部件的集成,请访问 如何显着增加社交媒体对您网站的 LIKE

<head>
     <script src="contentslocker.js" type="text/javascript"></script>
 </head>
 <body>
     ...
     <div class="irBodyLocker">
         <p>The rest of the article is locked</p>
         <p>To continue reading, become our friend pressing one of the buttons</p>

         ...put here the social widgets

     </div>
     <div class="irLockedBody" style="display:none;">

         ...put here the locked contents

     </div>
 </body>

The IdeaR.ContentsLocker.lockContents function is invoked by the script.

IdeaR.ContentsLocker.lockContents = function ()
 {
     $(function ()
     {
         if (IdeaR.ContentsLocker.socialActivity() == true)
         {
             $('div.irBodyLocker').hide();
             $('div.irLockedBody').show();
         }
         // Add social handlers only if contents are locked
         else
             $(function ()
             {
                 // Facebook
                 var exsistingFbAsyncInit = window.fbAsyncInit;
                 if (exsistingFbAsyncInit == null)
                     window.fbAsyncInit = 
                         IdeaR.ContentsLocker._subscribeFacebookLike();
                 else
                     window.fbAsyncInit = function ()
                     {
                         exsistingFbAsyncInit();
                         IdeaR.ContentsLocker._subscribeFacebookLike();
                     };

                 // Twitter
                 twttr.ready(function (twttr)
                 {
                     twttr.events.bind('tweet', 
                         IdeaR.ContentsLocker.ontwitteraction);
                     twttr.events.bind('follow', 
                         IdeaR.ContentsLocker.ontwitteraction);
                 });
             });
     });
 };

 IdeaR.ContentsLocker.socialActivity = function ()
 {
     return IdeaR.ContentsLocker._getCookie(
         IdeaR.ContentsLocker._socialAction, 'false') == 'true' ? true : false;
 };

 IdeaR.ContentsLocker._getCookie = function (name, defaultValue)
 {
     var docCookies = document.cookie.split(";");
     for (var i = 0; i < docCookies.length; i++)
     {
         var equalPos = docCookies[i].indexOf('=');
         var currentName = unescape(docCookies[i].substr(0, equalPos));
         currentName = currentName.replace(/^\s+|\s+$/g, '');
         if (currentName == name)
         {
             var value = docCookies[i].substr(equalPos + 1);
             return unescape(value);
         }
     }
     return defaultValue;
 };

 IdeaR.ContentsLocker._socialAction = 'SocialAction';

 IdeaR.ContentsLocker._subscribeFacebookLike = function ()
 {
     FB.Event.subscribe('edge.create', function (targetUrl)
     {
         IdeaR.ContentsLocker.unlockContents();
     });
 };

 IdeaR.ContentsLocker.ontwitteraction = function (intent_event)
 {
     if (intent_event)
         IdeaR.ContentsLocker.unlockContents();
 };

IdeaR.ContentsLocker.unlockContents = function ()
 {
     $('div.irBodyLocker').slideUp(400, function ()
     {
         $('div.irLockedBody').fadeIn();
     });
     IdeaR.ContentsLocker.saveSocialAction();
 };

 IdeaR.ContentsLocker.saveSocialAction = function ()
 {
     IdeaR.ContentsLocker._setCookie(
         IdeaR.ContentsLocker._socialAction, true, 10000);
 };

 IdeaR.ContentsLocker._setCookie = function (name, value, expirationDays)
 {
     var cookieString = escape(name) + '=' + escape(value);
     if (expirationDays != null)
     {
         var expirationDate = new Date();
         expirationDate.setDate(expirationDate.getDate() + expirationDays);
         cookieString += '; expires=' + expirationDate.toUTCString();
     }
     document.cookie = cookieString;
 };
于 2013-03-28T13:00:20.670 回答
0

我推荐以下插件:http ://codecanyon.net/item/like-2-unlock-for-wordpress/2858703?ref=onepress

于 2012-11-03T09:54:13.190 回答