В статье "Похожие статьи Blogger" прозвучал вопрос:
А есть ли более простой способ - без картинок, списком?
Скрипт я позаимствовала у JMiur, знаниям которого может любой позавидовать. Каждый раз, когда вы попадаете на страницу, будут показаны разные случайные результаты, а не последние статьи, которые написаны под данным ярлыком. Для демонстрации заглянем ещё раз в Приложение1.
На вкладке "Шаблон" после <b:if cond='data:blog.metaDescription == ""'>
<!-- Then use the post body as the schema.org description,
for good G+/FB snippeting. -->
<div class='post-body entry-content' expr:id='"post-body-" + data:post.id' itemprop='description articleBody'>
<data:post.body/>
<div style='clear: both;'/> <!-- clear for photos floats -->
</div>
<b:else/>
<div class='post-body entry-content' expr:id='"post-body-" + data:post.id' itemprop='articleBody'>
<data:post.body/>
<div style='clear: both;'/> <!-- clear for photos floats -->
</div>
</b:if>
добавить
<b:if cond='data:blog.pageType == "item"'>
<b:if cond='data:post.labels'>
<script>
//<![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 cuantosPosts = 0;
var r = Math.floor((relatedTitles.length - 1) * Math.random());
var i = 0;
var dirURL = document.URL;
document.write('<ul>');
while (i < relatedTitles.length && i < 50) {
if (relatedUrls[r] != dirURL) {
document.write('<li><a href="' + relatedUrls[r] + '" title=" ' + relatedTitles[r] + '">' + relatedTitles[r] + '</a></li>');
}
if (r < relatedTitles.length - 1) {
r++;
} else {
r = 0;
}
i++;
cuantosPosts++;
if (cuantosPosts == 3) {
break;
}
}
document.write('</ul>');
}
function mixRelatedLabels() {
for(var i = 0; i < relatedTitles.length; i++){
var indice = Math.floor((relatedTitles.length - 1) * Math.random());
var tempTitle = relatedTitles[i];
var tempUrls = relatedUrls[i];
relatedTitles[i] = relatedTitles[indice];
relatedUrls[i] = relatedUrls[indice];
relatedTitles[indice] = tempTitle;
relatedUrls[indice] = tempUrls;
}
}
//]]>
</script>
<b:loop values='data:post.labels' var='label'>
<b:if cond='data:label.name != "название_ярлыка_который_не_нужно_учитывать"'>
<script expr:src='"/feeds/posts/default/-/" + data:label.name + "?alt=json-in-script&callback=related_results_labels&max-results=30"'/>
</b:if>
</b:loop>
<div class="pohozhie-stayi">Похожие материалы:
<script>
removeRelatedDuplicates();
mixRelatedLabels();
printRelatedLabels();
</script>
</div>
</b:if>
</b:if>
max-results=30 - это максимальное количество статей фида ярлыка, из которых будут выбираться заголовки для показа. Чем выше значение, чем более разнообразнее будут результаты, но скорость загрузки страниц будет медленнее.
cuantosPosts == 3 - это количество ссылок в блоке с "Похожими материалами".
Условие, выделенное цветом при отсутствии востребованности удаляется.
Список можно расположить и в боковой панели, если фрагмент
<div class="pohozhie-stayi">Похожие материалы:
<script>
removeRelatedDuplicates();
mixRelatedLabels();
printRelatedLabels();
</script>
</div>поместить в гаджет HTML/JavaScript.
Перед ]]></b:skin> при желании можно добавить стили, например,
.pohozhie-stayi {
margin-top: 1em; /* отступ между статьёй и блоком с ссылками на похожие записи */
}
.pohozhie-stayi li a {
padding-left: 20px;
}
53 комментария:
два вопроса:
- У меня между вариантами появилась горизонтальная пунктирная линия. Где её убрать?
- Как сделать отступ между Ярлыками и Похожими материалами? Не могу найти в коде, куда br вставить...
.widget .pohozhie-stayi li {
border-top: none;
}
Отступ
<b:if cond='data:blog.pageType == "item"'></br></br>
Похожие материалы:
Есть хороший способ выводить через json и гугловский api, там всё кратко, но руки не доходят довести до ума(.
.widget .pohozhie-stayi li {
line-height: 5%;}
Добавить маркеры
.widget .pohozhie-stayi li {
list-style: square outside;}
Что то или я не так сделал или я не так сделал.
К стати. у меня два
Ставил и после одного и после другого - результат - нулевой.
Заранее спасибо за помощь.
А может вы как спец глянете на поля к колонках как можно сократить пустое пространство?
1)Фото отчет зелёный лук на гидропонике за 15 дней
2)Выращивание рассады. Лук порей на гидропонике
Объединяем в "лук".
Если читатель захочет узнать ещё что-нибудь про лук, то он обратиться к этой странице. Это часть навигации.
Вам нужно пересмотреть все ярлыки. Одной статье - один/два ярлыка. Всего у блога должно быть не более 15 ярлыков, чтобы человек не запутался. У меня их шесть.
Что делает скрипт: выбирает несколько (количество вами указанное) сообщений из страниц, которым присвоен один ярлык.
.main-inner {
padding-right: 0;
padding-left: 0;
}
Все работает. Надо срочно сделать экспорт, что бы потом можно было восстановить... Есть у Вас странички на сайте, где описано как делать экспорт блога? Я знаю только как сохранить код.
Еще раз спасибо.
.main-inner .columns {
padding-left: $(main.column.left.width);
padding-right: $(main.column.right.width);
}
Не меняйте код, добавьте ниже нужный фрагмент.
внес изменения в шаблон, но скрипт не отображает виджет
http://dumudumal.blogspot.com/
подскажите, что не так сделал.
спасибо
Может быть несколько вхождений кода, например, для мобильной версии.
У меня в шаблоне почему-то три фрагмента кода data:post.body/.
Какой выбрать?
<b:if cond='data:blog.metaDescription == ""'>
<!-- Then use the post body as the schema.org description,
for good G+/FB snippeting. -->
<div class='post-body entry-content' expr:id='"post-body-" + data:post.id' itemprop='description articleBody'>
<data:post.body/>
<div style='clear: both;'/> <!-- clear for photos floats -->
</div>
<b:else/>
<div class='post-body entry-content' expr:id='"post-body-" + data:post.id' itemprop='articleBody'>
<data:post.body/>
<div style='clear: both;'/> <!-- clear for photos floats -->
</div>
</b:if>
третий проигнорируйте, он для мобильной версии.
Я не могу понять, в чем дело. Я перепробовал этих скриптов за сегодня тридцать пять миллионов - ни один не работает. Ваш аналогично. Что может быть?
Спасибо.
Строку
<div class="pohozhie-stayi">Похожие материалы:
замените на
<div class="pohozhie-stayi"> <strong>Похожие материалы:</strong>
В CSS
.pohozhie-stayi strong {
font-size: 150%;
}
Вопрос - в список включается текущая статья, как её убрать?