CMS Eleanor - Поиск
Полная версия этой страницы: Официальный форум Eleanor CMS » [php][/php] - покажите пример работы
Официальный форум Eleanor CMS » Поддержка пользователей системы Eleanor CMS » Первые шаги
Виктор
Очень порадовало наличие такой функции в редакторе. Например, мне нужно на странице среди прочей информации вывести 5 последних новостей сайта содержащие слово "колбаса", в виде обычного списка. Что я должен [php][/php] какой код я должен вставить?

В описание релиза об этом теге написано очень скупо:
Цитата
[php]...[/php] - все, что находится между этими тегами будет воспринято как PHP код и будет выполнено.
Skyff
Виктор, А что тут ещё должны были написать? Может список всех возможных скриптов которые туда можно вставить. :D
Чтоб что то вывести нужен код, для каждой нужды свой код, а пишут код программисты, а программистам кушать хочется :)
Вообще в дальнейшем может между этими тегами можно будет вставлять переменные которые будут что то выводить или что то похожее...
А вообще все скрипты хранятся в файловом архиве, если там нужного нету, нужно заказывать или ждать пока кто то напишет для общего пользования.
termit
А вообще туда можно впихнуть например следующее...

echo 'привет';

В результате получим
Цитата
привет
:sarcastic_hand:
Виктор
Цитата
echo 'привет';


это все понятно, Вопрос в другом, можно ли работать с Базой данных сайта? Выводить значения и что для этого нужно.
Код писать мне не обязательно, просто конструкцию...
Alexander
Виктор, можно писать любой PHP код.


$Mainclass->Db->Query('');
Виктор
Спасибо, когда меня примут в группу Eleanor user, сайт в каталоге на модерации, написал сюда support@eleanor-cms.ru, но пока не получил ответа...
Виктор
Цитата
Виктор, можно писать любой PHP код.

вот например мне на определенной странице модуля FAQ всередине контента нужно вывести последние список последних новостей с этого же сайта, при редактировании этой странице в редактор добавляю следующее:

бла-бла-бла

[php]$old_ending=$Mainclass->Url->ending;
$Mainclass->Url->ending=$ending;
$Mainclass->url_pref=$Mainclass->Url->DynamicBegin().$Mainclass->Url->ConstructUrl(array('module'=>$m_name),false,false).$Mainclass->Url->GetDel();
$Mainclass->Url->ending=$old_ending;

$data=$Mainclass->Cache->Get('archive_'news'_'5,false);
if($data===false)
{
	$data=array();
	$Mainclass->Db->Query('SELECT EXTRACT(YEAR_MONTH FROM `date`) `q`, COUNT(`id`) FROM `f_'.$m_name.'` WHERE `status`=1 GROUP BY `q` ORDER BY `q` DESC LIMIT '.$limit,__file__,__line__);
	while($arr=$Mainclass->Db->Fetch_row())
	$data[$arr[0]]=$arr[1];
	$Mainclass->Cache->Put('archive_'news'_'5,$data,3600,false);
}
$content=array();
foreach($data as $k=>$v)
{
	$k=substr_replace($k,'-',4,0);
	$content[]='<a href="'.$Mainclass->url_pref.$Mainclass->Url->ConstructUrl(array(array('date'=>$k)),false).'">'.Strings::UcFirst(Strings::HumanDate($k)).' ('.$v.')</a>';
}
$content=join('<br />',$content);
[/php]

бла-бла-бла


после сохранения выдает только: бла-бла-бла бла-бла-бла

Как мне правильно написать php код чтобы выводились новости?

termit
А где
echo $content
?
Код по ходу у тебя работает, вот только вывода нету...
Alexander
[b]Виктор[/b], вы же элементарно забыли вывести результат :)
Виктор
может еще что то забыл, все равно не выводит...

бла-бла-бла

[php noparse]$old_ending=$Mainclass->Url->ending;
$Mainclass->Url->ending=$ending;
$Mainclass->url_pref=$Mainclass->Url->DynamicBegin().$Mainclass->Url->ConstructUrl(array('module'=>$m_nam</span>e),false,false).$Mainclass->Url->GetDel();
$Mainclass->Url->ending=$old_ending;

$data=$Mainclass->Cache->Get('archive_'news'_'5,false);
if($data===false)
{
	$data=array();
	$Mainclass->Db->Query('SELECT EXTRACT(YEAR_MONTH FROM `date`) `q`, COUNT(`id`) FROM `f_'.$m_name.'` WHERE `status`=1 GROUP BY `q` ORDER BY `q` DESC LIMIT '.$limit,__file__,__line__);
	while($arr=$Mainclass->Db->Fetch_row())
	$data[$arr[0]]=$arr[1];
	$Mainclass->Cache->Put('archive_'news'_'5,$data,3600,false);
}
$content=array();
foreach($data as $k=>$v)
{
	$k=substr_replace($k,'-',4,0);
	$content[]='<a href="'.$Mainclass->url_pref.$Mainclass->Url->ConstructUrl(array(array('date'=>$k)),false).'">'.Strings::UcFirst(Strings::HumanDate($k)).' ('.$v.')</a>';
}
$content=join('<br />',$content);
echo $content;
[/php]

бла-бла-бла
Alexander
[b]Виктор[/b], уберите параметр noparse.
Виктор
этот параметр добавился уже в редакторе форума при переходе в расширенный режим при добавлении на страницу его нет...



бла-бла-бла

[php]$old_ending=$Mainclass->Url->ending;
$Mainclass->Url->ending=$ending;
$Mainclass->url_pref=$Mainclass->Url->DynamicBegin().$Mainclass->Url->ConstructUrl(array('module'=>$m_nam</span>e),false,false).$Mainclass->Url->GetDel();
$Mainclass->Url->ending=$old_ending;

$data=$Mainclass->Cache->Get('archive_'news'_'5,false);
if($data===false)
{
	$data=array();
	$Mainclass->Db->Query('SELECT EXTRACT(YEAR_MONTH FROM `date`) `q`, COUNT(`id`) FROM `f_'.$m_name.'` WHERE `status`=1 GROUP BY `q` ORDER BY `q` DESC LIMIT '.$limit,__file__,__line__);
	while($arr=$Mainclass->Db->Fetch_row())
	$data[$arr[0]]=$arr[1];
	$Mainclass->Cache->Put('archive_'news'_'5,$data,3600,false);
}
$content=array();
foreach($data as $k=>$v)
{
	$k=substr_replace($k,'-',4,0);
	$content[]='<a href="'.$Mainclass->url_pref.$Mainclass->Url->ConstructUrl(array(array('date'=>$k)),false).'">'.Strings::UcFirst(Strings::HumanDate($k)).' ('.$v.')</a>';
}
$content=join('<br />',$content);
echo $content;
[/php]

бла-бла-бла
Alexander
И что, не работает это вариант? О_о
Виктор
Нашел в чем была ошибка: в настройках был отключен редактор, поставил Eleanor BB-редактор и все стало выводиться

Jack Boss
Здравствуйте!
Написал такое:
[php]
echo "TEST";
global $Mainclass;
$query = 'SELECT *  FROM `sudoku_teams`';
$Mainclass->Db->Query($query,__file__,__line__);
while($record = $Mainclass->Db->Fetch_row()) 
{
$idTeam = $record['idTeam'];
echo $idTeam;
}
[/php]

В таблице две записи. Ничего не видает. С других таблиц аналогично, даже со стандартних. В чем проблема?
Запись в таблицу работает.
Alexander
Jack Boss, Вам нужно почитать специфигацию функции *fetch_row . Вы, наверное, привыкли к тому, что многие в своих разработках под этой функцией подразумевают fetch_array? Используйте Fetch_assoc()
Jack Boss
Цитата (Alexander @ 2011-02-28, 17:56)
Jack Boss, Вам нужно почитать специфигацию функции *fetch_row . Вы, наверное, привыкли к тому, что многие в своих разработках под этой функцией подразумевают fetch_array? Используйте Fetch_assoc()

Я ни к чему не привык, так как на php не програмировал. Просто смотрел, как у других сделано.
Спасибо ограмное за помощь, все пошло.
Пошел копаться дальше.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.