Ini pertanyaan dari Sahabat saya, cara membuat artikel terkait dengan tag <select> dan <option>.
Demo :
Contohnya akan berlaku sampai 21 Mei 2011 21:00 WIB, dan akan saya ganti seperti sebelumnya karena ini demo template.
Cara membuatnya
Dari Dashboard > Design > Edit HTML
Langkah pertama > Penempatan kode CSS
dibawah <b:skin><![CDATA[
........
diatas ]]></b:skin>
.post-footer h3
{border-bottom:2px double #000; font-size:15px; font-weight:bold; color:#000; margin:10px 0 3px; padding:4px 0 4px 5px}
Kode css diatas untuk judul "Artikel Terkait".
Langkah kedua > Penempatan Kode JavaScript
dibawah ]]></b:skin>
........
diatas </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('<select style="margin:10px 0;" onchange="document.location.href=this.options[this.selectedIndex].value;" name="artikelterkait" title="Artikel Terkait">');
while (i < relatedTitles.length && i < 20) {
document.write('<option style="padding:0 10px;" value="' + relatedUrls[r] + '">' +
relatedTitles[r] + '</option>');
if (r < relatedTitles.length - 1) {
r++;
} else {
r = 0;
}
i++;
}
document.write('</select>');
}
//]]>
</script>
Langkah ketiga > Penempatan kode HTML
dibawah <body>
........
diatas </body>
Lebih detailnya dibawah post-footer-line-3 atau line yang terakhir blog anda :
<div class='post-footer-line post-footer-line-4' style='margin-top:50px;'>
<b:if cond='data:post.labels'>
<b:loop values='data:post.labels' var='label'>
<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>
</b:if>
<b:if cond='data:blog.pageType == "item"'>
<h3>More Artikel:</h3>
<script type='text/javascript'>
removeRelatedDuplicates();
printRelatedLabels();
</script>
</b:if>
</div>
Semoga Pertanyaannya terjawab... :D
Jika ingin artikel terkait seperti biasa, anda bisa lihat disini :
Membuat Artikel Terkait atau More Article
Alhamdulillah
Comments
Post a Comment