2007年5月29日星期二

Blogger相关文章模块升级版

就像我博客一样显示BLogger相关文章的Hack模块,是根据文章的标题来判断文章的相关性。PurpleMoggy的这个Hack是根据标签来判断文章相关性的,应该更合适一些。

1.把下面代码放在《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('

    ');
    while (i < relatedTitles.length && i < 20) {
    document.write('
  • ' + relatedTitles[r] + '
  • ');
    if (r < relatedTitles.length - 1) {
    r++;
    } else {
    r = 0;
    }
    i++;
    }
    document.write('
');
}
//]]>
《/script》


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'>《/a》《b:if cond='data:label.isLast != "true"'》,《/b:if》
《/b:loop>
《/b:if>


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'>,
《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=10"' type='text/javascript'/》
《/b:if>
《/b:loop>
《/b:if>


4.保存模板,并转到“页面元素”中,添加一个HTML/Javascript模块,在里面填上下面代码,并保存。

《script type="text/javascript"》
removeRelatedDuplicates();
printRelatedLabels();
《/script》


5.再回到Html编辑,选中“扩展窗口小部件模板 ”。

《b:widget id='HTML13' locked='false' title='Related Posts' 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/》 《/b:if>
《div class='widget-content'》
《data:content/》
《/div>
《b:include name='quickedit'/》
《/b:if》
《/b:includable》
《/b:widget>


自定义部分:通过蓝色标记(即i < 20和max-results=10)出的部分我们可以自定义显示相关文章的数目。页面加载速度和相关文章的数目之间的平衡自己掌握好了。
注:请将文章中的"《 》"换为"< >"

HEMiDEMi Technorati Del.icio.us MyShare個人書籤 Yahoo

0 评论: