May 9, 2007

[翻译]显示相关文章

原文:Related Posts
  在看到 Hoctro 一个类似的 hack 文章后,我一下想到了这个点子。但不太走运的是,他要求所有的文章标题都有一个相同的前缀,而我希望按照标签显示相关的文章。我想用新的 JSON 格式做点什么。而我也在 Beautiful Beta 上阅读了关于如何解析 JSON 属性的文章。
  如果你的标签中使用了任何 url 保留字符,比如“?”“/”。这个属性可能不会正常工作。在这里我没有对 url 进行编码。
  首先,进入“模板 -> 编辑 HTML”。粘贴下面代码到 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>

  保存后点击“展开窗口小部件代码”。找到 blog1 部件中的下列代码:
<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>

  一般来说是在 post-footer-line 段下面(不论是行 -1,-2 还是 -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:if cond='data:blog.pageType == "item"'>
<script expr:src='"/feeds/posts/default/-/" + data:label.name + "?alt=json-in-script&amp;callback=related_results_labels&amp;max-results=10"' type='text/javascript'/>
</b:if>
</b:loop>
</b:if>

  粗体字的 3 行就是我添加的代码。;)
  保存。“模板 -> 界面元素”中添加一个“HTML/Javascript 部件”。我把它放在了文章部件下面。请在上面的代码正常工作的情况下添加这个部件。在部件中粘贴下面的代码:
<script type="text/javascript">
removeRelatedDuplicates();
printRelatedLabels();
</script>

  现在回到“编辑 HTML”,展开模板代码,找到你刚才添加的“HTML/Javascript 部件”。看起来应该类似于下面这样。添加粗体部分:
<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/></h2>
</b:if>
<div class='widget-content'>
<data:content/>
</div>

<b:include name='quickedit'/>
</b:if>
</b:includable>
</b:widget>

  在第一部分代码中的 < results="10.">用来调整相关文章的显示数量。

0 comments:

Twitter Delicious Facebook Digg Stumbleupon Favorites More

 
Powered by Blogger