Новости Joomla

Совет по Joomla: $db->getQuery(true) стал устаревшим

Совет по Joomla: $db->getQuery(true) стал устаревшим

👩‍💻 Совет по Joomla: $db->getQuery(true) стал устаревшим.Раньше при создании запросов в базу данных мы всегда получали объект запроса с помощью метода

getQuery(). Если передавался параметр
$new =
true, то получали новый запрос. Если без - последний.

use Joomla\CMS\Factory;$db = Factory::getContainer()->get('DatabaseDriver');$query = $db->getQuery(new: true);// и строим запрос
Под капот Joomla 4 вошёл Joomla Framework (PHP фреймворк а-ля Laravel, Yii и т.д.), а для Joomla 5 он обновился - версия 3.4.1 вышла 6 октября 2023г. В методе фреймворка есть примечание о том, что параметр
$new, который передавался в метод
getQuery() помечен как устаревший и будет удалён в версии фреймворка 4.0.
The parameter $new is deprecated and will be removed in 4.0, use %s::createQuery() instead.В Joomla 4 версия Joomla Framework была 2.x., в Joomla 5 - 3.x. Поэтому есть предположение, что с выходом Joomla 6 обновится и версия фреймворка - станет 4.0. Поэтому для получения объекта для новых запросов следует использовать метод
createQuery(). Он уже представлен в ядре и широко используется. При этом метод
getQuery() останется, но, скорее всего, будет выполнять функцию только геттера - получения текущего запроса.
@joomlafeed#joomla #php #разработка

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

kreker92

  • Захожу иногда
  • 393
  • 18 / 0
VirtueMart 3.8.8

Google не давал результатов, поэтому я пишу сюда свое решение.

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

Ошибку видно даже на официальной демо virtuemart: http://demo.virtuemart.net/pagination?start=24&limit=60

Мне в голову пришла только идея обнулять параметр limitstart при изменении limit.

Код
// через ssh находим файл с javascript
$ fgrep -rl display-number components/com_virtuemart/
components/com_virtuemart/views/category/tmpl/default.php
...
// находим там, что метод рендера селекта. Называется он getResultsCounter
$ fgrep -r getResultsCounter .
...
./administrator/components/com_virtuemart/helpers/vmpagination.php: public function getResultsCounter()
...

В файле находим строчки
Код
if(empty($limits) or !is_array( $limits )) {
        if($this->_perRow === 1) $this->_perRow = 5;
        $limits[$this->_perRow*5] = JHtml::_( 'select.option', JRoute::_( $link.'&limit='.$this->_perRow*5, false ), $this->_perRow*5 );
        $limits[$this->_perRow*10] = JHtml::_( 'select.option', JRoute::_( $link.'&limit='.$this->_perRow*10, false ), $this->_perRow*10 );
        $limits[$this->_perRow*20] = JHtml::_( 'select.option', JRoute::_( $link.'&limit='.$this->_perRow*20, false ), $this->_perRow*20 );
        $limits[$this->_perRow*50] = JHtml::_( 'select.option', JRoute::_( $link.'&limit='.$this->_perRow*50, false ), $this->_perRow*50 );
}
if(!array_key_exists( $this->limit, $limits )) {
        $limits[$this->limit] = JHtml::_( 'select.option', JRoute::_( $link.'&limit='.$this->limit, false ), $this->limit );
        ksort( $limits );
}
$selected = JRoute::_( $link.'&limit='.$selected, false );
$js = 'onchange="window.top.location.href=this.options[this.selectedIndex].value.slice(0,
this.options[this.selectedIndex].value.lastIndexOf(\'/\'))"';

И обнуляем в них limitstart
Код
if(empty($limits) or !is_array( $limits )) {
        if($this->_perRow === 1) $this->_perRow = 5;
        $limits[$this->_perRow*5] =  JHtml::_( 'select.option', JRoute::_( $link.'&'.$this->prefix.'limitstart=0&limit='.$this->_perRow*5, false ), $this->_perRow*5 );
        $limits[$this->_perRow*10] = JHtml::_( 'select.option', JRoute::_( $link.'&'.$this->prefix.'limitstart=0&limit='.$this->_perRow*10, false ), $this->_perRow*10 );
        $limits[$this->_perRow*20] = JHtml::_( 'select.option', JRoute::_( $link.'&'.$this->prefix.'limitstart=0&limit='.$this->_perRow*20, false ), $this->_perRow*20 );
        $limits[$this->_perRow*50] = JHtml::_( 'select.option', JRoute::_( $link.'&'.$this->prefix.'limitstart=0&limit='.$this->_perRow*50, false ), $this->_perRow*50 );
}
if(!array_key_exists( $this->limit, $limits )) {
        $limits[$this->limit] = JHtml::_( 'select.option', JRoute::_( $link.'&limit='.$this->limit, false ), $this->limit );
        ksort( $limits );
}
$selected = JRoute::_( $link.'&'.$this->prefix.'limitstart=0&limit='.$selected, false );

B теперь при изменении количества товаров для отображения мы всегда переходим на первую страницу  *DRINK*
Все вопросы и предложения на почту.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывод названий всех категорий и товаров в них на главной ((vm3))

Автор PavelK

Ответов: 0
Просмотров: 2251
Последний ответ 15.02.2022, 14:34:52
от PavelK
[Решено] Список товаров на главной VirtueMart

Автор vitoxa_ya

Ответов: 6
Просмотров: 10226
Последний ответ 21.10.2020, 23:27:08
от alfa212
Удаление всех товаров из корзины одним кликом.

Автор Chifu

Ответов: 10
Просмотров: 9118
Последний ответ 19.04.2020, 20:21:03
от grub
Сортировка в VirtueMart 2 по умолчанию, по наличию товаров и по цене

Автор vfxbro

Ответов: 7
Просмотров: 3748
Последний ответ 27.04.2019, 09:51:05
от rsn
Модуль VirtuMart Товары. Вывод товаров с определенным настраиваемым полем

Автор rsn

Ответов: 0
Просмотров: 879
Последний ответ 27.04.2019, 09:33:16
от rsn