Новости Joomla

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

👩‍💻 Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях. На старте его сайт на Joomla 3 вообще не смог обновиться на Joomla 5. Пришлось делать экспорт/импорт материалов. Проделав всё это он запустил-таки этот объём данных на Joomla 5. Тестовый скрипт грузил 200 материалов из этого объёма всего за 94 секунды ))) А главная страница с категориями грузилась 20 секунд. Добавив индекс для таблицы #__content

CREATE INDEX idx_catid_state ON #__content (catid, state);
он сократил время загрузки категорий до 1 секунды. Затем наш герой решил поковырять SQL-запрос в ArticleModel, который отвечает за выборку материалов. И решил заменить тип JOIN на STRAIGHT_JOIN для категорий.
// ->from($db->quoteName('#__content', 'a'))->from(    $db->quoteName('#__content', 'a')    . ' STRAIGHT_JOIN ' . $db->quoteName('#__categories', 'c')    . ' ON ' . $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))// ->join('LEFT', $db->quoteName('#__categories', 'c'), $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))
Что сократило загрузку 200 материалов из 150к с 94 секунд до 5. К слову сказать, боевой сайт на Joomla 3 крутится на 12CPU 64GB рамы. А все манипуляции с кодом он делает на базовом 1CPU 1GB сервере и замеры скорости даны именно для базового сервера. Но это всё в дискуссии, хотя в идеале должно вылиться в Pull Requests. Мы - Open Source сообщество, где никто никому ничего не должен. Джунгли. Но человек ищет пути оптимизации Joomla и предлагает решения. Если оказать поддержку и предложить помощь хотя бы с тестированием самых разнообразных сценариев, то возможно эти улучшения смогут войти в ядро. Пусть не быстро, пусть через несколько лет, пусть не все, но войдут. Достаточно предложить руку помощи и приложить немного усилий.
Дискуссию на GitHub можно почитать здесь.@joomlafeed#joomla #community #php

Перевод и публикация интервью с Joomla евангелистом на греческом портале Joomla

Перевод и публикация интервью на греческом портале Joomla 🇬🇷

Утро, просматриваешь входящие письма и изучаешь новости и внезапно обнаруживаешь, что инициатива, которую ты начал, подхватывается другими людьми. 🎉

Недавно я взял интервью у Билла (Василиса) Коциаса - руководителя студии, читающего лекции в университете и популяризатора Joomla в Греции. Это интервью из журнала NorrNext, в оригинале на английском, теперь доступно на греческом языке и опубликовано на портале joomla.gr. 🎉

До чего же приятно… 😇😊 Работа замечена и с ней посчитали необходимым ознакомить аудиторию страны, в которой Билл читает лекции. И это солнечная Греция - страна, страна, с которой Россию многое связывает. 🇬🇷🇷🇺🕊

Смотрю на греческий алфавит и тут же рисуются картины белоснежных зданий в окружении винограда и амфор, красивых женщин в сандалиях и мужественных воинов, охраняющих покой полисов, в которых ученые мужи работают над трудами, позже вошедшими в века. Красиво! 😇Но вернемся к интервью.

Из него вы узнаете, что в Греции доля Joomla среди CMS занимает порядка 30-40%. По моему мнению это - самый высокий показатель во всем мире. Также чтение лекций о Joomla в университетах позволит привести новых пользователей и к тому же молодое поколение. Ну и огромное кол-во сертификтатов Билла на стене (смотрим фото в статье) свидетельствует о том, что Joomla может применяться как профессиональный инструмент.

🌐 Оригинальное интервью (на английском)
🇬🇷 Интервью на греческом портале (joomla.gr)

Что насчет перевода на русский? Увы, времени всего 24 часа в сутках. Я продолжаю готовить новые интервью. Возможно, после завершения выпуска журнала, рассмотрю перевод некоторых интервью на русский. Но я об этом не говорил. 😊 В блоге @eugenius_blog публикую анонсы интересных событий из мира Joomla, интервью, уроки и полезные советы, а также делюсь мыслями:, связанными с разработкой и веб-дизайном.

0 Пользователей и 1 Гость просматривают эту тему.
  • 10 Ответов
  • 4175 Просмотров
*

ExJTMaster

  • Осваиваюсь на форуме
  • 11
  • 3 / 0
AJAX пагинация товара
« : 13.02.2017, 19:03:45 »
Сделал AJAX пагинацию товара по кнопке "Показать еще товары"

В файл шаблона /list_products/list_products.php
в конце перед последним </div> добавить код кнопки
Код
<div class = "more-product"><button class = "show-more btn btn-default" onclick="showmore()">Показать еще</button></div>
и в конце файла добавить скрипт
Код
<script>
function showmore(){
var lasturl = jQuery(".pagination li").last().find("a").attr("href");
if (lasturl){
var ajax_products_url = jQuery(".pagination li").eq(-2).find("a").attr("href")+"&tmpl=component";
jQuery.ajax({
url: ajax_products_url,
dataType: "html",
type: "GET",
cache: false,
success: function (result) {
var newContent = jQuery('<div/>').append(result).find(".list_product");
var newPagination = jQuery('<div/>').append(result).find("ul.pagination");
jQuery('.more-product').replaceWith(newContent.children());
jQuery('ul.pagination').replaceWith(newPagination);
lasturl = jQuery(".pagination li").last().find("a").attr("href");
if (!lasturl){
jQuery('.more-product').html("");
}
}
});
} else {
jQuery('.more-product').html("");
}
}
</script>
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: AJAX пагинация товара
« Ответ #1 : 13.02.2017, 19:14:21 »
AJAX пагинацию сделать несложно. сложно сделать чтобы она правильно ботами поисковыми вопринималась. и чтобы кнопка Назад в браузере нормально работала. и т.п. а саму кнопочку Показать еще сделать несложно :) но в любом случае спасибо что поделились.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

ExJTMaster

  • Осваиваюсь на форуме
  • 11
  • 3 / 0
Re: AJAX пагинация товара
« Ответ #2 : 13.02.2017, 19:17:56 »
AJAX пагинацию сделать несложно. сложно сделать чтобы она правильно ботами поисковыми вопринималась. и чтобы кнопка Назад в браузере нормально работала. и т.п. а саму кнопочку Показать еще сделать несложно :) но в любом случае спасибо что поделились.
Должна правильно поисковиками обрабатываться, так как фактически блок пагинации остается, его можно скрыть стилями, для поисковика все по старой схеме работает.
Назад тоже верно работает, возвращает на предыдущую страницу
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: AJAX пагинация товара
« Ответ #3 : 14.02.2017, 01:27:40 »
tmpl=component не забыть от индексации закрыть
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

intcorp

  • Захожу иногда
  • 456
  • 12 / 0
Re: ajax пагинация товара
« Ответ #4 : 08.11.2018, 17:40:29 »
Хорошее решение, но, когда достигается конец позиций, кнопку , в идеале, нужно было бы скрыть, иначе начинает подгружать уже загруженные позиции.

П.с. если сейчас есть новые решения данного вопроса, поделитесь ссылочкой)
« Последнее редактирование: 08.11.2018, 18:37:55 от intcorp »
*

kadriel

  • Новичок
  • 3
  • 0 / 0
Re: ajax пагинация товара
« Ответ #5 : 29.04.2019, 01:20:51 »

П.с. если сейчас есть новые решения данного вопроса, поделитесь ссылочкой)

+1 ^-^
*

Gringo7

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: ajax пагинация товара
« Ответ #6 : 02.10.2019, 11:52:59 »
Немного другая реализация данного метода, с сокрытием кнопки, когда показывать нечего.

В самый конец list_products.php (после дива list_product) добавляем кнопку.
Код
<div id = "more-products" class = "hidden"><button onclick="showmore()">Показать еще</button></div>
И вставляем скрипт:
Код
<script>
    //После загрузки страницы проверяем, показывать ли кнопку Показать еще
    jQuery(function() {
        show_hide_btn();
    });

    function show_hide_btn() {
        //Проверяем, есть ли ссылка на след. страницу
        nexturl = jQuery(".pagination ul li.pagination-active").next().find("a").attr("href");
        // Если нашли, показываем кнопку
        if (nexturl) {
            jQuery("#more-products").removeClass("hidden");
        }
        // Если нет, скрываем
        else {
            jQuery("#more-products").addClass("hidden");
        }
    }

    function showmore(){
            nexturl = jQuery(".pagination ul li.pagination-active").next().find("a").attr("href");
        if (nexturl) {
            jQuery.ajax({
                url: nexturl,
                dataType: "html",
                type: "GET",
                cache: false,
                success: function(data){
                //    Вырезаем нужный нам код из ответа
                    var   add_html = jQuery(data).find(".list_product").html();
                    var   newPg = jQuery(data).find(".pagination").html();
                //    и вставляем его на страницу
                    jQuery(".list_product").append(add_html);
                    jQuery(".pagination ul").replaceWith(newPg);
                },
                error: function (error) {
                    console.log('Error sending AJAX request\nStatus code: ' + error.status + '\nStatus text: ' + error.statusText);
                },
                complete: function () {
                    //Проверяем, показывать ли кнопку Показать еще
                    show_hide_btn();
                }
                })
        }
    }
    </script>

Не использовал tmpl=component в url запроса, т.к. в этом случае сервер возвращает блок пагинации, где в ссылках тоже стоит этот параметр, что, естественно, не нужно. Возможно, это только мой случай, разбираться не стал, на скорость особо не влияет. И убрал обертывание ответа в div (('<div/>').append), браузер ругается на конструкцию. Думаю тоже особо не влияет.
*

goga_pgasovav

  • Захожу иногда
  • 445
  • 6 / 0
  • Внимательный джумловод
Re: ajax пагинация товара
« Ответ #7 : 12.10.2020, 15:36:25 »
Товарищи, взял за основу реализацию AJAX-пагинации от Gringo7.
Работает всё без нареканий. НО!
В пагинации, возвращаемой аяксом, какие-то модифицированные странными символами урлы получаются.
Например ссылка на первую страницу должна выглядеть так:
Код
http://mysite.com/mycategory?start=0
А AJAX возвращает следующее:
Код
http://mysite.com/mycategory?_=1602506113717&start=0
Отуда берётся это «_=1602506113717&» ?  :o
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Re: ajax пагинация товара
« Ответ #8 : 12.10.2020, 15:53:47 »
Отуда берётся это «_=1602506113717&» ? 
Вероятно, это работа параметра cache: false в запросе jQuery.ajax(); - он таким образом предотвращает кэширование гет-запроса браузером.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

goga_pgasovav

  • Захожу иногда
  • 445
  • 6 / 0
  • Внимательный джумловод
Re: ajax пагинация товара
« Ответ #9 : 12.10.2020, 16:01:34 »
sivers, огомное вам спасибо! Помогло. С AJAX раньше вообще дел не имел, и не знал, что такой параметр существует.
*

sivers

  • Живу я здесь
  • 2596
  • 360 / 0
Re: ajax пагинация товара
« Ответ #10 : 12.10.2020, 16:20:18 »
Помогло. С AJAX раньше вообще дел не имел, и не знал, что такой параметр существует.
Да пожалуйста. К слову, если отправлять запрос методом POST (параметр type: "GET" поменять на type: "POST"), то кэширования не будет в любом случае - пост-запросы не кэшируются.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

В списке товаров вывести названия категорий каждого товара

Автор shop-user

Ответов: 5
Просмотров: 3089
Последний ответ 25.01.2022, 06:05:12
от kit2m2
Плагин - Инфоблок товара в списке товаров [Скачать]

Автор kit2m2

Ответов: 13
Просмотров: 3215
Последний ответ 20.10.2021, 14:51:08
от kit2m2
Автоматическая генерация кода товара (плагин)

Автор maslybs

Ответов: 8
Просмотров: 3627
Последний ответ 30.08.2021, 20:21:25
от nevigen
Таблица размеров (и т.п.) Плагин модульных позиций для атрибутов на странице товара [Скачать]

Автор kit2m2

Ответов: 39
Просмотров: 8173
Последний ответ 16.05.2021, 18:16:50
от kit2m2
Усовершенствованый фильтр 3.4.0(ajax)

Автор seetvael

Ответов: 252
Просмотров: 44887
Последний ответ 06.08.2020, 14:57:19
от goga_pgasovav