google blogger 如何添加"相关文章"功能方法

2009年5月4日星期一

苦寻了半日,终于在一点一滴的博客中找到了方法,但其中有个代码不对,后又在大鼻子的百度空间里找到了一些方法,终于搞定,现在分享与大家。
一般显示Blogger相关文章的功能模块,是根据文章的标题来判断文章的相关性。这个方法功能是根据标签来判断文章相关性的,看来更合适一些。(注:标签中不能包含像?/之类的字符)

1.点击---布局--修改HTML----选中“扩展窗口小部件模板 ”后,把下面代码放在HTML的<head></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>

注:其中的"i < 12"是控制文章数量的,建议数值不要太大,以免影响浏览速递

2.在代码中找到下面的部分

<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:loop>
</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&max-results=12"' type='text/javascript'/>
</b:if>
注:max-results=12部分为文章显示条数,不要设太大,根据自已需要设置即可

3.保存模板,并转到“页面元素”中,添加一个HTML/Javascript模块,在里面填上下面代码,并添加标题为“相关文章”并保存。
<script type="text/javascript">
removeRelatedDuplicates();
printRelatedLabels();
</script>

4.再回到Html编辑,选中“扩展窗口小部件模板 ”。找到
<b:widget id='HTML13' locked='false' title='相关文章' type='HTML'>
<b:includable id='main'>
<!-- only display title if it's non-empty -->
<b:if cond='data:title != ""'>
<h2 class='title'><data:title/></h2>
</b:if>
<div class='widget-content'>
<data:content/>
</div>
<b:include name='quickedit'/>
</b:includable>
</b:widget>


<b:widget id='HTML13' locked='false' title='相关文章' type='HTML'>
<b:includable id='main'>
后面添加
<b:if cond='data:blog.pageType == "item"'>
找到

</b:includable>
</b:widget>
在前面添加
</b:if>


完成后 此段代码应是这样的:
<b:widget id='HTML13' locked='false' title='相关文章' type='HTML'>
<b:includable id='main'>
<b:if cond='data:blog.pageType == "item"'>
<!-- only display title if it's non-empty -->
<b:if cond='data:title != ""'>
<h2 class='title'><data:title/></h2>
</b:if>
<div class='widget-content'>
<data:content/>
</div>
<b:include name='quickedit'/>
</b:if>
</b:includable>
</b:widget>

注:个人添加的元素项其id不一定是HTML13,可根据自己设置相应的title='相关文章'进行搜索。

好了 ,点击保存看看效果了,总体还是很不错的,不过本人不喜欢这个“相关文章”在最底部,觉得应该在帖子下面就好了 。方法肯定是有的,等我找到在传上来吧!


转帖请注明出处:google blogger 如何添加"相关文章"功能方法 - 独孤一剑的博客

0 comments

发表评论

相关文章