回到首页
订阅Luke瞎折腾
找资源前务必先看这里!!
Blogger技巧
免费空间推荐
Luke的网络收藏夹
Luke的网络硬盘
控制台
新建日志

2009/04/12

让Blogger显示相关文章

字体大小:| |
相信很多WordPress的用户都很喜欢“在日志下显示相关文章”这一功能,这样能给读者带来更好的浏览体验。而我们Blogger用户就惨了,BlogSpot居然没有提供这个功能- =,好在Google还是很开放的,能让我们自己修改模板添加功能。刚刚结合了色彩斑斓写写改改™的方法,终于实现了这个功能,现在就来分享一下吧。

1.控制台-布局-修改 HTML,保存一下模板以备不测,然后勾选“扩展窗口小部件模板”

2.将以下代码添加到<head>与</head>之间,Luke推荐直接添加在</head>之前
<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>


3.查找以下代码:
<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 != "true"'>,</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 != "true"'>,</b:if>
<b:if cond='data:blog.pageType == "item"'>
<script expr:src='"/feeds/posts/default/-/" + data:label.name + "?alt=json-in-script&callback=related_results_labels&amp;max-results=10"' type='text/javascript'/>
</b:if>
</b:loop>
</b:if>


4.将下面红色代码放到自己想要显示相关文章的位置。Luke是放在评论前的,如下面黑色代码。(每个模板的具体代码不同,仅供参考!实际操作时请多试几次。)
相关文章:
<b:if cond='data:blog.pageType == "item"'>
<script type='text/javascript'> removeRelatedDuplicates(); printRelatedLabels(); </script> </b:if>
<div class='comments' id='comments'>
<a name='comments'/>
<b:if cond='data:post.allowComments'>
<h4>
<b:if cond='data:post.numComments == 1'>
1 <data:commentLabel/>:
<b:else/>
<data:post.numComments/> <data:commentLabelPlural/>:
</b:if>
</h4>


5.保存模板,查看效果。

注:
1.本Hack是根据标签来判断文章相关性的,注意标签中不能包含像“?”、“/”、“'”之类的字符,对文章的标签数量也没有限制

2.代码中蓝色的“i < 20”和“max-results=10”决定了相关日志的显示数目,显示的越多,网页加载越慢,所以具体的显示数量请自己斟酌。

3.Hoctro's Place还提供了更为先进的方法(使用了Ajax Feed API from Google),有空的话Luke会尝试一下并发布具体方法。



-------------------------------------------------------------------------------------
以上图片和文字均为原创,转载请注明转自Luke瞎折腾


收藏本文
相关文章:

7 评论:

匿名 说... 回复此评论

我失败~\(≧▽≦)/~啦啦啦
“错误信息:The reference to entity "callback" must end with the ';' delimiter.”
有解决办法吗?

Luke 说... 回复此评论

@banana
现在在用手机上的网,等我用上电脑了再看一下哦:)

匿名 说... 回复此评论

哦在http://blog.ibelen.com/2007/01/blogger_18.html试了试成功了,你的第3步和他有点不一样

我一点html都不懂啊。。。疑惑的很。。。

Luke 说... 回复此评论

@banana

恩,是我的代码少了“amp;”但是不知道为什么输入后Blogger显示不出来,正在修正ing...

Luke 说... 回复此评论

@banana

那部分代码已经修正好了,不知道其他地方有没有问题,今天快要熄灯了,改天有空了我再测试下吧。

Blogger的发布啊...唉...

苯苯 说... 回复此评论

我已经照着每一个步骤了,可是我的blogger的相关文章还是没办法弄。
请问可以有另一个方法吗?

Luke 说... 回复此评论

@苯苯

代码应该是没有问题的,可能是你在插入文中红色代码的位置有错误,你可以先保存下模板,然后多试几次。

明天要开学了,要去学校,可能不能及时帮到你了,抱歉。

发表评论

有问题请留言,Luke帮你解决。问了方便回答,请尽量不要匿名。