Artigo atualizado em: 15 de Janeiro 2010
Encontrei essa no Usuário Compulsivo e achei bem interessante postar aqui. Só lembrando que não apliquei nenhuma modificação no hack.
Este hack permite a seleção automática aleatória de todos os seus posts, determinando quantos e quais artigos aparecerá abaixo de cada post. É um ítem bastante importante para deixar os usuários que acessam seu blog por mais tempo navegando e descobrindo novos artigos de interesse próprio.
Para adicioná-lo entre em “Layout/Editar HTML”, marque a caixinha “Expandir modelos widgets” e procure pela tag: </head>
Cole o seguinte código antes da tag citada acima:
<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>
Salve o template. Ainda com a caixa “Expandir modelos de widgets” marcada procure pelo código abaixo:
<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>
E cole antes da tag em negrito acima o seguinte trecho:
<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>
Agora pra finalizar procure a seguinte linha:
<div class=’post-footer-line post-footer-line-3’/>
E adicione depois:
<b:if cond=’data:blog.pageType == “item”‘><h3>Artigos relacionados</h3></b:if>
<script type=’text/javascript’>
removeRelatedDuplicates();
printRelatedLabels();
</script>
Pronto, vizualize e veja se não ocorreu nada de errado e salve.
Créditos: IceBreaker
É esse mesmo que você usa no seu blog ? Percebi que na sua home os links relacionados não aparecem, no meu blog http://simplesmentenetiinho.blogspot.com aparece na home os assuntos relacionados, quero mudar isso, responda se é esse que você usa, tentei mais não consegui. Desde já obrigado.
@- netiinho ॐ
Realmente não é esse que uso aqui no blog, uso um outro Hack que funciona da mesma forma só que usando imagens e títulos.
Ainda não criei um artigo sobre este gadget mais você pode conferir
aqui como instalá-lo no seu blog.