форум vBSupport.ru > vBulletin > vBulletin 3.8.x > Вопросы по vBulletin 3.8
  • »
VBsupport перешел с домена .ORG на родной .RU Ура! Пожалуйста, обновите свои закладки - VBsupport.ru
 
 
 
 
Gostemilov
Специалист
Default BB-code в HTML
1

Давно хотел сделать ленту новых тем, но не только по заглавию, как List All Threads, а с первым постом. Ну, руки дошли и заняло это 3 минуты.

Но. При выводе pagetext из post он выводится, естественно, в неизмененном виде (что, в общем-то, как раз противоетстественно)



Вопрос - как подключить соотвествующую (знал бы, как называется - не спрашивал) функцию форума для парсинга pagetext в нормальный HTML? Или это делается более запутанным путем?

Спасибо
Bot
Yandex Bot Yandex Bot is online now
 
Join Date: 05.05.2005
Реклама на форуме А что у нас тут интересного? =)
 
 
kerk
k0t
 
kerk's Avatar
Default
3

перед циклом подключаем файл класса ббкодов (глобальный объект $vbulletin уже должен существовать в этой видимости скрипта, чаще всего, подключением файла глобал.пхп в самом начале кода)
PHP Code:
require_once(DIR'/includes/class_bbcode.php');
$parser = new vB_BbCodeParser($vbulletinfetch_tag_list()); 
и в цикле (while или foreach) выполняем парсинг текста
PHP Code:
$post['pagetext'] = $parser->do_parse($post['pagetext'], falsetruetruefalsetruefalse); 
аргументы функции do_parse() можно посмотреть в самом файле класса
 
 
Gostemilov
Специалист
Default
2

Жесть. Нет, ты все-таки или гений или около того. Да, пришлось подправить 1 параметр в do_parse



Это именно то, чего я добивался. Преогромное спасибо!

UPD - мало ли кому пригодится

PHP Code:
    while ($thread $vbulletin->db->fetch_Array($result_thread) AND $counter++ < $perpage)
    {
        
$count++;

// DIV
$divnumunhtmlspecialchars($thread['firstpostid']);
$result_post $vbulletin->db->query_read("SELECT * FROM " TABLE_PREFIX "post WHERE postid=$divnum");

require_once(
DIR'/includes/class_bbcode.php');
$parser = new vB_BbCodeParser($vbulletinfetch_tag_list()); 

while (
$div $vbulletin->db->fetch_Array($result_post))
    {
        
$divtext=unhtmlspecialchars($div['pagetext']);
        
$divtext $parser->do_parse($divtextfalsetruetruetruetruefalse);  
    }
// DIV 
 
 
kerk
k0t
 
kerk's Avatar
Default
3

цикл в цикле - не очень хорошая затея =)
тем более создавать объекты в циклах без особой на то необходимости
код
PHP Code:
require_once(DIR'/includes/class_bbcode.php');
$parser = new vB_BbCodeParser($vbulletinfetch_tag_list()); 
вынести за пределы цикла
и вот это $divnum= unhtmlspecialchars($thread['firstpostid']); не имеет никакого смысла =)
т.к. в поле firstpostid всегда целое число
весь код можно уместить в 2-4 запроса
сначала считаем кол-во тем (для постраничной навигации)
затем собираем ID-шники тем
затем, собираем ID-шники первых постов из тем (ограничивая perpage в коде запроса)
затем, собираем текст постов по ID-шникам из первого запроса

итого должно получиться максимум 4 запроса на страницу, а не три-пять десятков =)
 
 
Gostemilov
Специалист
Default
0

Дык это, барин... Мы энто, сиволапые, с такой скоростью код писать не умеем... Работает - сейчас буду оптимизировать код, а насчет unhtmlspecialchars($thread['firstpostid']); - это не ко мне, это к GiveMeABreak, это его

А вообще логика-то понятна, сам так и думал, просто не успел. Но пока не представляю, как сделать это

Quote:
сначала считаем кол-во тем (для постраничной навигации)
затем собираем ID-шники тем
затем, собираем ID-шники первых постов из тем (ограничивая perpage в коде запроса)
затем, собираем текст постов по ID-шникам из первого запроса
Вместо кучи запросов я , помозговав, уложился в один

Code:
	$result_thread = $vbulletin->db->query_read("SELECT * FROM " . TABLE_PREFIX . "thread LEFT JOIN " . TABLE_PREFIX . "post  ON thread.firstpostid = post.postid ORDER BY " . TABLE_PREFIX . "$sqlsort $order LIMIT $pos,$perpage");
	$counter = 0;
	$count = 0;

require_once(DIR. '/includes/class_bbcode.php');
$parser = new vB_BbCodeParser($vbulletin, fetch_tag_list()); 

	while ($thread = $vbulletin->db->fetch_Array($result_thread) AND $counter++ < $perpage)
	{
		$count++;
		$divtext=unhtmlspecialchars($thread['pagetext']);
		$divtext = $parser->do_parse($divtext, false, true, true, true, true, false);
Мна все правильно сделал или можно еще улучшить?

UPD. Включив остатки головного мозга, сообразил, что даже в 15 постах на страницу может быть куча текста и иллюстраций, что вызовет непомерный вес страницы с вытекающими

Итак,

Code:
//DIV
		$divtext=unhtmlspecialchars($thread['pagetext']);
		$divtext = words_limit($divtext);  
		$divtext = $parser->do_parse($divtext, false, true, true, true, true, false);
//DIV
и

Code:
function words_limit($input_text, $limit = 100, $end_str = '') {
    $input_text = strip_tags($input_text);
    $words = explode(' ', $input_text);
    if ($limit < 1 || sizeof($words) <= $limit) {
        return $input_text;
    }
    $words = array_slice($words, 0, $limit);
    $out = implode(' ', $words);
    return $out.$end_str;
}

позволяют изяЧно вывести первые 100 или сколько там надо слов из поста....

Last edited by Gostemilov : 10-05-2015 at 09:30 PM.
 


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off




All times are GMT +4. The time now is 11:45 PM.


Powered by vBulletin® Version 3.8.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Loading...