现在我就来说明如何添加“相关文章”模块,即在每篇文章下面出现与此文章标签相关的文章,其实很简单,只需要两部就可以实现了。
1.进入 控制台 , 布局 再进入 修改HTML 页面,最好先备份自己的模板,以免出错不好恢复。
勾选 扩展窗口小部件模板 前的勾,添加以下 css及javascript代码 到 </head> 前面
<style>
#related-posts {
float : left;
width : 540px;
margin-top:20px;
margin-left : 5px;
margin-bottom:20px;
font : 11px Verdana;
margin-bottom:10px;
}
#related-posts .widget {
list-style-type : none;
margin : 5px 0 5px 0;
padding : 0;
}
#related-posts .widget h2, #related-posts h2 {
color : #940f04;
font-size : 15px;
font-weight : normal;
margin : 5px 7px 0;
padding : 0 0 5px;
}
#related-posts a {
color : #054474;
font-size : 11px;
text-decoration : none;
}
#related-posts a:hover {
color : #054474;
text-decoration : none;
}
#related-posts ul {
border : medium none;
margin : 10px;
padding : 0;
}
#related-posts ul li {
display : block;
background : url("http://i263.photobucket.com/albums/ii150/mohamedrias/newconcept_bullet.png") no-repeat 0 0;
margin : 0;
padding-top : 0;
padding-right : 0;
padding-bottom : 1px;
padding-left : 16px;
margin-bottom : 5px;
line-height : 2em;
border-bottom:1px dotted #cccccc;
}
</style>
<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>
2.找到 <p><data:post.body/></p> 如果不好找可以按 Ctrl+F 查找,或者复制 所有代码到记事本中查找。有的模板就只有 <data:post.body/> 所以就找 <data:post.body/> 就行了,因为我的模板两边就没有 <p> </p> ,找到后并在其后加入如下代码保存就可以了。
<b:if cond='data:blog.pageType == "item"'>
<div id="related-posts">
<h2>与 <b:loop values='data:post.labels' var='label'><data:label.name/><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&max-results=5"' type='text/javascript'/></b:if></b:loop> 相关的文章:</h2>
<script type='text/javascript'> removeRelatedDuplicates(); printRelatedLabels(); </script>
</div>
</b:if>
看别人的文章尾巴后面都跟一个相关文章,可以让读者继续关注你的Blog,搜索了一下,发现方法还挺多的,作者shinetree.lung上的不错,大家可以去看看,我就不多说了,具体要注意的就是,当你要修改的时候一定要先备份原来的模版代码,以免出错不好恢复,还有就是要勾选扩展窗口小模块,如果不勾选,会导致有些代码找不到,还有一个最大的问题就是,作者给的那段代码当中有个图片链接,一定要修改掉,换成你自己的图片,因为那图片禁止外部链接。
1 评论:
座沙发
发表评论