Новости 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 Гость просматривают эту тему.
  • 4 Ответов
  • 3573 Просмотров
*

james may

  • Новичок
  • 5
  • 0 / 0
Добрый день. Собственно, скачал BF.
Необходимо было сделать форму с одним списком и группой чекбоксов.
У каждого элемента как списка, так и чекбокса есть свое числовое значение.
В конце надо, допустим, посчитать сумму.

Форму создавал через QuickMode

Вот Actionsript списка

Код
function ff_apps_action(element,action) {
ff_amountowing_action(element,action);
}

Тоже самое у группы чекбоксов, только в строчке function ff_apps_action(element,action) apps изменено на ages.

Сумма, которую надо получить выводится в текстовое поле.
Вот actionsript этого самого поля
Код
function ff_amountowing_action(element,action)
{
   ff_getElementByName('amountowing').value = 0;
   if (ff_getElementByName('ages').checked)
   {
      ff_getElementByName('amountowing').value = Number(ff_getElementByName('amountowing').value) + Number(ff_getElementByName('ages').value);
   }
   if (ff_getElementByName('apps').ff_valuenotempty)
   {
ff_getElementByName('amountowing').value = Number(ff_getElementByName('amountowing').value) + Number(ff_getElementByName('apps').value);
}
}

Подскажите пожалуйста, где может быть ошибка и как ее исправить. Уже второй день сижу и как не старайся, ничего не получается.
В данном случае срабатывает только первый чекбокс из группы. При нажатии же других, как и при выборе элемента из списка ничего не происходит :(
*

shmakatuha

  • Захожу иногда
  • 131
  • 3 / 0
С этим вопросом в компоненте есть проблемы при использовании чекбоксов. Зависит от версии вроде.
По моему, где-то видел ответ на официальном форуме компонента: http://crosstec.de/forums.html
*

Dominus

  • Осваиваюсь на форуме
  • 18
  • 4 / 0
Посмотри как выполняются подобные действия в примере Pizza shop на 4-й странице формы.
*

james may

  • Новичок
  • 5
  • 0 / 0
С этим вопросом в компоненте есть проблемы при использовании чекбоксов. Зависит от версии вроде.
По моему, где-то видел ответ на официальном форуме компонента: http://crosstec.de/forums.html

искал уже, там есть ответ про суммирование обычных чекбоксов, никак не связанных между собой, и черт с ними, но как к этому делу еще и список приписать?

Посмотри как выполняются подобные действия в примере Pizza shop на 4-й странице формы.
в пицце используются чекбоксы, как отдельный элемент.

Ну и опять же, пусть будут отдельным элементом, главное, как к суммированнию привязать еще и значения списка
*

Dominus

  • Осваиваюсь на форуме
  • 18
  • 4 / 0
Для классического режима, задача решается следующим образом:

Код  чекбоса и селектлист. Пишется в поле Скрипт действие. Действие для чекбоксов ставим Нажатие, а селект листа Change. Для группы чекбоксов пишется только в первом чекбоксе, в остальных просто ставим действие Нажатие.

Код
function ff_имя_элемента_action(element, action)
{
    switch (action) {
        case 'click':
             ff_calculate();
            break;
        default:;
    } // switch
} // ff_имя_элемента_action

Скрипт текстового поля ( пишется в поле Проверка скрипта)

Код
function ff_имя_текстового_поля_validation(element, message)
{
       ff_calculate();
   return '';
} // ff_имя_текстового_поля_validation

// создаём функцию расчёта и вывода результата
function ff_calculate()
{
var order = 0;
 // присваиваем переменной order значение из selectlist
    order = Number(ff_getElementByName('имя_селектлист').value);

 // вычисляем и присваиваем переменной order значения чекбоксов
    for (var i = 0; i < ff_elements.length; i++)
        if (ff_elements[i][2]=='имя_чекбокса')
            if (ff_getElementByIndex(i).checked) order += Number(ff_getElementByIndex(i).value);

 // вывод результата
    ff_getElementByName('имя_текстового_поля').value = order;
}
//ff_calculate

Готово!
« Последнее редактирование: 31.01.2011, 03:29:50 от Dominus »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Может кто подскажет. Передача данных в форму?

Автор black-gyrza

Ответов: 0
Просмотров: 1899
Последний ответ 20.09.2013, 21:19:24
от black-gyrza
Select region - ссылки в элементах списка

Автор Wharfadale

Ответов: 7
Просмотров: 6268
Последний ответ 19.07.2009, 11:13:49
от Wharfadale