2009年3月16日星期一

如何在Blogger里添加相关文章

所谓的相关文章其实指的就是显示和你当前浏览的文章有关的其它文章,目前我所看到的相关文章都是利用了Blogger本身的标签功能,也就是说和当前文章相同标签的其它文章会被显示出来。

至于这个功能有什么好处呢?最直接的好处就是延长你部落格的游客的逗留时间。当你的游客对你部落格的某篇文章感到兴趣的时候,他说不定也会对你的其它相似类型的文章有兴趣。因此,若是有添加相关文章的功能的话,游客在看完你的文章后,马上就可以注意到你的文章下方的相关文章,他马上就可以继续阅读他所感兴趣的文章,自然就会延长逗留的时间。而只要逗留的时间长到一定的程度,游客就会变成定期的访客,甚至订阅你的部落格,所以说这个功能其实相当的重要。

那当然,其实很多人已经介绍过在Blogger里添加相关文章插件的方法,不过我没有喜欢过那种方法。原因是:相关文章如果不能够在读者看完文章后自然发现的话,那就一点意义也没有了!而我所看到的插件都不能达到这一点,所以之前我都没有添加到这个功能,一直到我使用了上一个模板后,不知道还有多少人对那个模板有印象呢?:)

总之,上一个模板本身就自带相关文章的功能的,不说插件说功能的原因是,要修改这个功能的话必须直接修改HTML代码才行。虽然我尝试去寻找回原本的作者,不过……所以作者暂时空缺,有人知道的话请通知我一声,谢谢!

然后现在就来进入主题了。首先到布局的修改HTML那里,

勾选扩展窗口小部件模板(当然,之前请记得备份)后,在]]></b:skin>之后添加以下代码:

<script type='text/javascript'>
//<![CDATA[
var relatedTitles = new Array();
var relatedTitlesNum = 0;
var relatedUrls = new Array();
function related_results_labels(json) {
for (var i = 0; i < json.feed.entry.length; i++) {
var entry = json.feed.entry[i];
relatedTitles[relatedTitlesNum] = entry.title.$t;
for (var k = 0; k < entry.link.length; k++) {
if (entry.link[k].rel == 'alternate') {
relatedUrls[relatedTitlesNum] = entry.link[k].href;
relatedTitlesNum++;
break;
}
}
}
}
function removeRelatedDuplicates() {
var tmp = new Array(0);
var tmp2 = new Array(0);
for(var i = 0; i < relatedUrls.length; i++) {
if(!contains(tmp, relatedUrls[i])) {
tmp.length += 1;
tmp[tmp.length - 1] = relatedUrls[i];
tmp2.length += 1;
tmp2[tmp2.length - 1] = relatedTitles[i];
}
}
relatedTitles = tmp2;
relatedUrls = tmp;
}
function contains(a, e) {
for(var j = 0; j < a.length; j++) if (a[j]==e) return true;
return false;
}
function printRelatedLabels() {
var r = Math.floor((relatedTitles.length - 1) * Math.random());
var i = 0;
document.write('<ul>');
while (i < relatedTitles.length && i < 20) {
document.write('<li><a href="' + relatedUrls[r] + '">' + relatedTitles[r] + '</a></li>');
if (r < relatedTitles.length - 1) {
r++;
} else {
r = 0;
}
i++;
}
document.write('</ul>');
}
//]]>
</script>

接着找寻以下代码:

<b:if cond='data:post.labels'>
          <data:postLabelsLabel/>
          <b:loop values='data:post.labels' var='label'>
            <a expr:href='data:label.url' rel='tag'><data:label.name/></a><b:if cond='data:label.isLast != &quot;true&quot;'>,</b:if>
          </b:loop>
        </b:if>

将整段替换成

<b:if cond='data:post.labels'>
          <data:postLabelsLabel/>
          <b:loop values='data:post.labels' var='label'>
            <a expr:href='data:label.url' rel='tag'><data:label.name/></a><b:if cond='data:label.isLast != &quot;true&quot;'>,</b:if>

<b:if cond='data:blog.pageType == &quot;item&quot;'>
<script expr:src='&quot;/feeds/posts/default/-/&quot; + data:label.name + &quot;?alt=json-in-script&amp;callback=related_results_labels&amp;max-results=10&quot;' type='text/javascript'/>
</b:if>

</b:loop>
        </b:if>

还没有结束咯,之前只是添加了javascript,以及让javascript能够接收标签的资料。真正的戏肉,也就是相关文章的功能还没有添加到。

先找一个合心意的地方来放相关文章的功能,个人建议放在标签的下面,也就是上面那段代码后,所见到的第一个</div>后面。不过当然如果你喜欢的话,也可以放在部落格文章栏的下面,也就是上面那段代码后,所见到的第一个</b:includable>之前。当然如果你觉得你喜欢放在文章前面的话,也是可以,不过请自个儿去寻找代码。

决定地方后,就添加以下那段代码:

<b:if cond='data:blog.pageType == &quot;item&quot;'><br/><h3 style='color:999999'>相关文章:</h3></b:if>
<script type='text/javascript'>
removeRelatedDuplicates();
printRelatedLabels();
</script>

蓝色那段是标题,不喜欢的话可以随便你改。红色那段是你的标题的颜色,不喜欢的话,当然更可以随便你改,至于颜色的代码可以上维基查询:http://zh.wikipedia.org/w/index.php?title=%E7%BD%91%E9%A1%B5%E9%A2%9C%E8%89%B2%E6%A8%A1%E5%BC%8F&variant=zh-cn

好了后就来看看效果吧!

相关文章在我部落格的效果点图可放大

linfavourite signature


没有评论:

LinkWithin

Related Posts Plugin for WordPress, Blogger...