2016-07-12 3 views
4

Здравствуйте!Joomla Ajax jQuery

У меня проблема с моей «пользовательской» разбивочной разбивочной страницей для компонента в joomla.

Я хотел сделать список статей пользователя, который будет показан для примера 3 сообщения на страницу. Моя цель состояла в том, чтобы сделать разбивку на страницы без обновляющей веб-страницы. Аякс был лучшим выбором. Я сражаюсь с ним прямо сейчас и имею самую сложную проблему до сих пор (я пытался найти ответ на мою проблему несколько часов).

User.php

<div class="userRightContainer"> 
      <div class="blogArticlesBlock"> 
      <div class="userItemTagsBlock"><b>Debaty na forum użytkownika(<?php echo $joomla_rows; ?>)</b></div> 

      <?//artykuly joomla 
      ?> 

     <div id="Joomla_block" class="Joomla_block"> 
      <? require_once("Db_joomla.php") ?> 
     </div> 

... 
... 
... 

<script type="text/javascript"> 

function jm_previous(arg) { 
    if(arg < 0) 
     changePagination(0); 
    else 
    changePagination(arg); 
} 
function jm_next(argument) { 
    changePagination(argument); 
} 

function changePagination(pageId){ 

        // $("#Joomla_block").html(''); 
    jQuery.ajax({ 
      type: "GET", 
      // url: "Db_joomla.php", 
      url: window.location.href, 
      data: { jm_start: pageId}, 
      success: function(result){ 
        alert(result); 
        $("#Joomla_block").html(result); 

      } 
     }); 
} 
</script> 

Db_joomla.php

defined('_JEXEC') or die; 
// 
$offset_jm=$_GET["jm_start"]; 
if(empty($offset_jm)) $offset_jm=0; 
// 
$db = JFactory::getDbo(); 
$query = $db->getQuery(true); 
$query->select($db->quoteName(array('id', 'title', 'introtext', 'created_by', 'state'))); 
$query->from($db->quoteName('#__content')); 
$query->where($db->quoteName('created_by') . ' LIKE ' . $db->quote(JRequest::getInt('id'))); 
$query->where('state', '1'); 
$query->setLimit($joomla_page,$offset_jm); 
$db->setQuery($query); 
$joomla=$db->loadObjectList(); 
$joomla_rows = $db->loadResult(); 


if($joomla_rows > 0){ 
foreach($joomla as $row) { 
if ($row->created_by != JRequest::getInt('id')) continue; 
?> 
      <div class="articlesBlock" style="margin: 5px;"> 
       <!-- Avatar --> 
     <img src="<?php echo $this->user->avatar; ?>" alt="<?php echo htmlspecialchars($this->user->name, ENT_QUOTES, 'UTF-8'); ?>" style="width:50px; height:auto;border: 1px solid #ccc; float:left;margin: 5px;" /> 
        <div class="blogArticlestTitle" style="padding-left:60px;font-weight:bold;word-wrap:break-word;"><a href="index.php?option=com_content&view=article&id=<?php echo $row->id;?>"><?php echo $row->title ?></a></div> 
        <div class="blogArticlesDescription" style="padding: 5px;padding-top:10px;"><?php if (str_word_count($row->introtext) > 100) echo /* Wstawia komentarz i ogranicza tekst do stu znaków, po czym dodaje kropki.*/ substr(strip_tags($row->introtext), 0, 100) . "..."; else echo strip_tags($row->introtext);?> 
        </div> 
        <div class="CommentViewMore"> 
        <a href="index.php?option=com_content&view=article&id=<?php echo $row->id;?>">Przejdź do artykułu ›</a> 
        </div> 
       </div> 
<?php 
/* 
    $item_counting++; 
    if($item_counting == 5) break;*/ 
         } 


//echo $pageNav->getListFooter(); //Displays a nice footer 
     ?> 
<ul class="pager"> 
    <li><a href="javascript:void(0)" id="jm_previous" onclick="jm_previous(<? echo $offset_jm-$joomla_page; ?>)" style="background-color: #000;float:left;"><<</a></li> 
    <li><a href="javascript:void(0)" id="jm_next" onclick="jm_next(<? echo $offset_jm+$joomla_page; ?>)" style="background-color: #000;float:right;">>></a></li> 
</ul> 
    <a class ="view_more_link"href="http://konfederaci.pl/index.php/component/komento/profile/id/<?php echo JRequest::getInt('id');?>" title="Artykuły użytkownika">Zobacz wszystkie artykuły</a> 
    <?php 
    } 
     else 
{ 

    echo "Ten użytkownik nie posiada żadnych postów na forum."; 
} 

Теперь несколько фотографий:

From alert(result)

From google chrome's console

Ps: Если я выбираю «URL: "Db_joomla.php" в этом сценарии он не будет делать ничего. все еще не работает (и то же исключение).

ответ

1

Всегда лучше полагаться на интерфейс Ajax от Joomla, а не на внедрение своих. Он очень прост и очень эффективен, и он работает. Мы написали о том, как использовать его here.

По существу, вы создадите/измените простой модуль, который будет содержать функцию (которая имеет слово Ajax в конце своего имени), которая будет использоваться для обработки вызова.

Затем вам нужно будет добавить простой код jQuery, который вызовет модуль через интерфейс com_ajax. Обратите внимание, что вам нужно будет убедиться, что модуль назначен для элемента меню, потому что вам потребуется идентификатор этого пункта меню для вызова ajax.

1

Просто практическая занятость: Ваша задняя часть ajax должна содержать только код PHP. (Получить запрос БД). Далее этот PHP должен возвращать массив JSON с результатами. Вы получаете этот JSON для запроса ajax и нажимаете эти данные для своего вида. Для просто использую my plugin "plg_ajax" (после установки см. Метод onAjaxAjax()). Пример сценария после этого плагина с com_ajax:

type: "POST", 
 
      async: true, 
 
      url: "index.php?option=com_ajax&plugin=ajax&format=json", 
 
      dataType: "json",