Membuat Related Post

Saya mendapat ide pertama setelah melihat tutorial dari Hoctro's similar hack. Prinsip ini menggunakan pemanfaatan dari Label/Kategori saat kita posting. Related Post akan menunjukkan posting yang mempunyai label sama. Ok. Langsung aja.

Pertama, buka Template -> Edit HTML and paste code berikut sebelum </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>


Save template, dan klick Expand Widget Template checkbox. Turunkan ke bawah dan cari widget ini:

<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>


It'll probably be down in the post-footer-line section (whether that be line-1, -2, or -3)

Tambahkan script baris yang tebal :

<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>


Save template, kemudian buka Template -> Page Elements dan add a new HTML/Javascript widget. Dengan Title Related Post.Paste script di bawahnya :

<script type="text/javascript">
removeRelatedDuplicates();
printRelatedLabels();
</script>


Sekarang kembali lagi ke Template -> Edit HTML, check pad checkbox untuk melihat dari template full dan cari HTML/Javascript widget Related Post yang kita add. Tambahkan baris yang tebal:

<b:widget id='HTML13' locked='false' title='Related Post' 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>

Jumlah dari related post yang di tampilkan dapat di atur dengan mengatur nilai max-results=10


Tutorial from : purplemoggy

COMMENTS :

Don't Spam Here 1

makasih banyak tetapi saya koq masih binging yak? ~x( http://www.pasamu.com disitu menyediakan gratis pasang iklan selama 2 bulan gratis om. hehehe... info aja

Anonymous said...
on 

Post a Comment

 

Copyright Harga HP Terbaru © 2010 - All right reserved. Powered by Wordpress Hostgator Hosting whos online