то ждем ваше обращение в нашей службе тех поддержки.
Пользовательские движки шаблонизации
				
Компоненты могут работать с любыми движками шаблонизации, которые могут быть подключены из PHP. Чтобы добавить новый движок шаблонизации на сайт необходимо определить (или дополнить) глобальную переменную $arCustomTemplateEngines в файле /bitrix/php_interface/init.php. В этой переменной содержится ассоциативный массив, каждый элемент которого имеет вид:
   "код_шаблонизатора" => array(
      "templateExt" => array("расширение1"[, "расширение2"...]),
      "function" => "имя_функции_подключения_движка"
   )
где:
- 
код_шаблонизатора- произвольное уникальное в рамках сайта слово,
- 
расширениеN- расширение файла, который должен обрабатываться этим движком шаблонизации,
- 
имя_функции_подключения_движка- имя функции, которая будет вызываться, если шаблон компонента имеет указанное расширение. Функцию можно разместить в этом же файле/bitrix/php_interface/init.php.
Например, если на сайте кроме стандартного движка шаблонизации (PHP) требуется использовать Smarty, то в файл /bitrix/php_interface/init.php необходимо добавить следующий код:
   global $arCustomTemplateEngines;
   $arCustomTemplateEngines = array(
      "smarty" => array(
         "templateExt" => array("tpl"),
         "function" => "SmartyEngine"
      ),
   );
Тогда при подключении шаблона с расширением tpl будет запускаться не стандартный движок PHP, а функция SmartyEngine, которая должна подключить движок Smarty.
Синтаксис функций подключения движков следующий:
function имя_функции_подключения_движка($templateFile, $arResult, $arParams, $arLangMessages, $templateFolder, $parentTemplateFolder, $template)
где:
- 
$templateFile– путь к файлу шаблона относительно корня сайта,
- 
$arResult– массив результатов работы компонента,
- 
$arParams– массив входных параметров компонента,
- 
$arLangMessages– массив языковых сообщений (переводов) шаблона,
- 
$templateFolder– путь к папке шаблона относительно корня сайта (если шаблон лежит не в папке, то эта переменная пуста),
- 
$parentTemplateFolder- путь относительно корня сайта к папке шаблона комплексного компонента, в составе которого подключается данный компонент (если компонент подключается самостоятельно, то эта переменная пуста),
- 
$template– объект шаблона.
Код функции подключения движка шаблонизации зависит от подключаемого движка.
Полный пример подключения движка Smarty
В файл /bitrix/php_interface/init.php необходимо добавить код:
global $arCustomTemplateEngines;
$arCustomTemplateEngines = array(
   "smarty" => array(
      "templateExt" => array("tpl"),
      "function" => "SmartyEngine"
   )
);
function SmartyEngine($templateFile, $arResult, $arParams, $arLangMessages, $templateFolder, $parentTemplateFolder, $template)
{
   if (!defined("SMARTY_DIR"))
      define("SMARTY_DIR", "/libs/");
   require_once('/libs/Smarty.class.php');
   $smarty = new Smarty;
   $smarty->compile_dir = "/templates_c/";
   $smarty->config_dir = "/configs/";
   $smarty->template_dir = "/templates/";
   $smarty->cache_dir = "/cache/";
   $smarty->compile_check = true;
   $smarty->debugging = false;
   $smarty->assign("arResult", $arResult);
   $smarty->assign("arParams", $arParams);
   $smarty->assign("MESS", $arLangMessages);
   $smarty->assign("templateFolder", $templateFolder);
   $smarty->assign("parentTemplateFolder", $parentTemplateFolder);
   $smarty->display($_SERVER["DOCUMENT_ROOT"].$templateFile);
}
Строку  нужно везде заменить на абсолютный путь к движку Smarty в рамках вашей установки. Подробности по установке движка на сайт есть в системе помощи по Smarty.
В примере кода в массиве $arCustomTemplateEngines регистрируется движок Smarty. В функции SmartyEngine инициализируются параметры движка в соответствии с требованиями системы (см. документацию Smarty). Далее в Smarty передаются переменные результатов работы компонента, входных параметров, языковых сообщений и т.д. И в конце вызывается метод обработки и показа шаблона Smarty.
Полный пример подключения движка XML/XSLT
В файл /bitrix/php_interface/init.php необходимо добавить код:
global $arCustomTemplateEngines;
$arCustomTemplateEngines = array(
   "xslt" => array(
      "templateExt" => array("xsl"),
      "function" => "XSLTEngine"
   ),
);
function CreateXMLFromArray($xDoc, $xNode, $ar)
{
   foreach($ar as $key=>$val)
   {
      if(!is_string($key) || strlen($key)createElement($key);
      if(is_array($val))
      {
         CreateXMLFromArray($xDoc, $xElement, $val);
      }
      else
      {
         $xElement->appendChild($xDoc->createTextNode(iconv(SITE_CHARSET, "utf-8", $val)));
      }
      $xNode->appendChild($xElement);
   }
   return $xNode;
}
function XSLTEngine($templateFile, $arResult, $arParams, $arLangMessages, $templateFolder, $parentTemplateFolder, $template)
{
   $arResult["PARAMS"] = array(
      "templateFolder" => $templateFolder,
      "parentTemplateFolder" => $parentTemplateFolder,
      "arParams" => $arParams,
      "arLangMessages" => $arLangMessages
   );
   $xDoc = new DOMDocument("1.0", SITE_CHARSET);
   $xRoot = $xDoc->createElement('result');
   CreateXMLFromArray($xDoc, $xRoot, $arResult);
   $xDoc->appendChild($xRoot);
   $xXsl = new DOMDocument();
   $xXsl->load($_SERVER["DOCUMENT_ROOT"].$templateFile);
   $xProc = new XSLTProcessor;
   $xProc->importStyleSheet($xXsl);
   echo $xProc->transformToXML($xDoc);
}
Назад в раздел
 Наверх
 Наверх