Генерация JS + CSS
Здравствуйте,
Возможна ли генерация JS и CSS непосредственно из тела расширения? То есть, отдельных файлов с изменяемым в процессе выполнения скрипта данными, которые будут связаны со выводимой страницей. В идеале - Smarty-конфигурируемые. Спасибо. |
Довольно странная задача... Обычно есть некие файлы, которые надо поключить, а затем где-нибудь в <head> вставить <script> только с изменяемыми в этом случае JS-переменными.
Добавить некий код в <head> можно через $GLOBALS['TSFE']->includeAdditionalCSS/includeAdditionalJS Для smarty смотрите расширение smarty, рекомендую в зависимостях указывать точную версию, т.к. расширение, видимо, будет часто изменяться в будущем. |
Спасибо за ответ, Алексей, данные методы и расширение уже используются, вопрос несколько специализирован.
Мои шаблоны CSS и JS - сквозные, идущие через весь сайт, с различными настройками каждый раз. Они должны быть динамическими, то есть создающимися на уровне PHP. Кроме того, я предпочитаю не загромождать код скрипт-переменными. И не создавать несколько десятков отдельных подключний. В идеале было бы наиболее уместно использовать отдельные Smarty-шаблоны CSS и JS, где переменные задаются на уровне Typo3, логика на уровне PHP, и презентация как финал процесса. |
Цитата:
То есть делать в шаблоне отдельный page.typeNum = XX Для него как угодно создавать контент - через TS или плагин (заголовки только указать правильные для http ответа). А на обычных страницах вместо page.includeCSS.main = fileadmin/style.css писать page.includeCSS.main = http://domain.com/?id=12&type=XX Можно даже попробовать сделать так, что бы стили и JS брались для каждой страницы по тому же id просто с другим параметром type. |
Благодарю за интересную рекоммендацию, в таком случае, я не постесняюсь спросить как и где наиболее лаконично Вы порекомендуете включить данный файл в head для всего сайта.
Спасибо. |
page.includeCSS.main = http://domain.com/?id=12&type=XX включает скрипт в <head> всего сайта.
Конфиг будет при этом примерно такой: Код:
printform = PAGE Существует другой подход - использовать технологию eID, но в этом случае кеширование вы должны будете реализовывать сами (если нуждаетесь в нем). |
Я думал над данным методом и задался вопросом в его гибкости.
Если скажем необходимо изменять параметры CSS файла в зависимости от результатов выполнения кода модуля - разве это достижимо здесь. Ведь TS - это самый первый этап в процессе исполнения. А если необходимо модифицировать оформление уже после генерации содержимого? |
Цитата:
Поэтому в таком случае Вы можете включить стили или JS в вашем плагине внутрь HTML кода (внутрь BODY) - перед или после вашего HTML контента. В таком случае стили добавятся или переопределятся, а JS подгрузится. |
Если вам нужна зависимость содержимого css/js от результата работы плагина, то можно добавлять их примерно так:
в плагине пишете PHP код:
|
Да, я еще можно поробовать хук:
Код:
$TYPO3_CONF_VARS["SC_OPTIONS"]["tslib/class.tslib_fe.php"]["contentPostProc-output"] = array("EXT:plugin/class.plugin.php:user_PluginPostProc->sParseOutput"); Хотя это может быть и не очень удобно.... |
Часовой пояс GMT +4, время: 07:13. |
Работает на vBulletin® версия 3.8.1.
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Перевод: zCarot