Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #461 (permalink)  
Старый 07.02.2015, 10:39
Аватар для Gozar
Отправить личное сообщение для Gozar Посмотреть профиль Найти все сообщения от Gozar
 
Регистрация: 07.06.2007
Сообщений: 7,504

В общем буду постить в этот коммент. Удалось таки запустить наследование...
html.ss
{template html(@param)}
    {doctype}
    <html lang="ru">
        <head>
            {block head}

                {block meta}
                        <meta charset="UTF-8">
                        <title>{param.title}</title>
                        <meta name="keywords" content="{param.meta_kwd}">
                        <meta name="description" content="{param.meta_des}">
                {/}

                {block style}
                {/}

                {block script}
                {/}

            {/block}
        </head>

        <body>
            {block body}
            {/block}
        </body>
    </html>
{/template}


main.ss
{include 'html.ss'}

{template main(param) extends html}

    {block style}
        {super}
        {link css}/css/style.css{/}
    {/}

    {block script}
        {super}
        {script js src = /js/lib/react.js}{/}
        {script js src = /js/lib/shim.js}{/}
    {/}

    {block body}
        {super}
        <div class="wrap">{param.title}</div>
    {/}

{/template}


вызов:
var tpl = require('../tpl/main.ss.js').init(require('snakeskin'));
var html = tpl.main({title:'Заголовок', meta_kwd:'ключевые, слова', meta_des: 'Много Текста Описания'});



Как можно заметить в main мы не вызываем напрямую {block head}: {block head}{super}{/} Он сам вызовется. В main мы просто дополняем блоки нужными нам данными. Причем место значения не имеет, можно хоть сначала написать {block body}, а в конце {block style}. Выводиться будет в порядке обозначенном в html.ss.
__________________
Последний раз редактировалось Gozar, Сегодня в 24:14.

Последний раз редактировалось Gozar, 07.02.2015 в 11:04.
Ответить с цитированием
  #462 (permalink)  
Старый 07.02.2015, 11:02
Аватар для Gozar
Отправить личное сообщение для Gozar Посмотреть профиль Найти все сообщения от Gozar
 
Регистрация: 07.06.2007
Сообщений: 7,504

kobezzza,
Советую добавить это пример как основной, чтобы люди себе мозг не трахали. Ты изобрел язык, а описание к нему очень скудное и не очевидное. Добавь вызовы, с передачей параметров, к примерам шаблонов. Вся очень просто, только когда знаешь.

Сейчас справка читается как псевдокод.
__________________
Последний раз редактировалось Gozar, Сегодня в 24:14.
Ответить с цитированием
  #463 (permalink)  
Старый 07.02.2015, 11:12
Аватар для Gozar
Отправить личное сообщение для Gozar Посмотреть профиль Найти все сообщения от Gozar
 
Регистрация: 07.06.2007
Сообщений: 7,504

Ещё такой вопрос.

Данные в базе я храню с переносами строки \n, а при выводе нужно заменить на <br>. В snakeskin есть встроенный механизм замены? Флаг или ещё что-то? Если нет, то чтобы не экранировало <br> использовать https://github.com/kobezzza/Snakeskin/wiki/data ?
__________________
Последний раз редактировалось Gozar, Сегодня в 24:14.
Ответить с цитированием
  #464 (permalink)  
Старый 07.02.2015, 13:31
Аватар для kobezzza
Быдлокодер;)
Отправить личное сообщение для kobezzza Посмотреть профиль Найти все сообщения от kobezzza
 
Регистрация: 19.11.2010
Сообщений: 4,338

Сообщение от Gozar Посмотреть сообщение
kobezzza,
Советую добавить это пример как основной, чтобы люди себе мозг не трахали. Ты изобрел язык, а описание к нему очень скудное и не очевидное. Добавь вызовы, с передачей параметров, к примерам шаблонов. Вся очень просто, только когда знаешь.

Сейчас справка читается как псевдокод.
Оки

Сообщение от Gozar Посмотреть сообщение
Выводиться будет в порядке обозначенном в html.ss.
Угу, а новые блоки, которых нет в родителе, добавятся в конец.

***

А почему ты пишешь param.title

Ты же забиндил параметр param c помощью with

https://github.com/kobezzza/Snakeskin/wiki/with

Т.е. ты можешь писать просто

@title


Сообщение от Gozar Посмотреть сообщение
Ещё такой вопрос.

Данные в базе я храню с переносами строки \n, а при выводе нужно заменить на <br>. В snakeskin есть встроенный механизм замены? Флаг или ещё что-то? Если нет, то чтобы не экранировало <br> использовать https://github.com/kobezzza/Snakeskin/wiki/data ?
Не совсем понял, что ты хочешь, т.е. у тебя есть параметр, который выводится и ты хочешь заменить там \n на br ?

{template some(param1)}
    {param1.replace(/\n/, '<br>')|!html}
{/}


Если я прав, то почитай главу (там кстати видео ещё есть)

https://github.com/kobezzza/Snakeski...80%D0%BE%D0%B2

https://github.com/kobezzza/Snakeski...BD%D0%B8%D0%B9

Ещё про output и call почитай.

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

PS: извини за долгий ответ, вчера был на тусе, а сегодня бошка трещит
__________________
kobezzza
code monkey

Последний раз редактировалось kobezzza, 07.02.2015 в 13:33.
Ответить с цитированием
  #465 (permalink)  
Старый 07.02.2015, 13:38
Аватар для kobezzza
Быдлокодер;)
Отправить личное сообщение для kobezzza Посмотреть профиль Найти все сообщения от kobezzza
 
Регистрация: 19.11.2010
Сообщений: 4,338

Ещё обратил внимание, что в твоём примере

{block body}
        {super}
        <div class="wrap">{param.title}</div>
{/}


Тут этот super не особо нужен, т.к. в родительском блоке ничего нет. Super в SS тоже самое что в ES6 и других языках с классами, т.е. просто вызов родителя и если его не использовать, то дочерний блок просто заменить родительскую реализацию, также следует отметить что super не обязательно должен быть в начале, т.е. можно вставить его в конец или середину и т.д. и это будет ожидаемо влиять на конечный код шаблона.
__________________
kobezzza
code monkey

Последний раз редактировалось kobezzza, 07.02.2015 в 13:42.
Ответить с цитированием
  #466 (permalink)  
Старый 07.02.2015, 13:48
sinistral
Посмотреть профиль Найти все сообщения от melky
 
Регистрация: 28.03.2011
Сообщений: 5,418

как бы заюзать SnakeSkin вместе с React?

как это сделать сначала шаблон компилим в HTML, а потом HTML в VDOM реакта?
Ответить с цитированием
  #467 (permalink)  
Старый 07.02.2015, 14:00
Аватар для Gozar
Отправить личное сообщение для Gozar Посмотреть профиль Найти все сообщения от Gozar
 
Регистрация: 07.06.2007
Сообщений: 7,504

Сообщение от melky
как это сделать сначала шаблон компилим в HTML, а потом HTML в VDOM реакта?
Как ты собираешься это сделать?. Это скомпилинная часть функции.
__RESULT__ += '<!DOCTYPE html>';
__RESULT__ += '<html lang="ru"> <head> ';
__RESULT__ += '<meta charset="UTF-8"> <title>';
__RESULT__ += __FILTERS__.html(__FILTERS__.undef(param.title), false, false);
__RESULT__ += '</title> <meta name="keywords" content="';
__RESULT__ += __FILTERS__.html(__FILTERS__.undef(param.meta_kwd), true, false);
__RESULT__ += '"> <meta name="description" content="';
__RESULT__ += __FILTERS__.html(__FILTERS__.undef(param.meta_des), true, false);
__RESULT__ += '"> ';
__________________
Последний раз редактировалось Gozar, Сегодня в 24:14.
Ответить с цитированием
  #468 (permalink)  
Старый 07.02.2015, 14:08
Аватар для Gozar
Отправить личное сообщение для Gozar Посмотреть профиль Найти все сообщения от Gozar
 
Регистрация: 07.06.2007
Сообщений: 7,504

Сообщение от kobezzza
с другой стороны такой фильтр может есть смысл добавить из коробки
Очень бы хотелось.

Сообщение от kobezzza
Т.е. ты можешь писать просто
@title
Ага, поменял. Постепенно доходит. Уже заюзал {forEach @menu => @el} Полёт нормальный
__________________
Последний раз редактировалось Gozar, Сегодня в 24:14.

Последний раз редактировалось Gozar, 07.02.2015 в 14:14.
Ответить с цитированием
  #469 (permalink)  
Старый 07.02.2015, 16:02
Аватар для kobezzza
Быдлокодер;)
Отправить личное сообщение для kobezzza Посмотреть профиль Найти все сообщения от kobezzza
 
Регистрация: 19.11.2010
Сообщений: 4,338

Цитата:
Как ты собираешься это сделать?. Это скомпилинная часть функции.
Ну он наверное имел ввиду работу с результатом работы шаблона, а SS как раз умеет формировать DocumentFragment, а не только строку.

Цитата:
Очень бы хотелось.
Думаю завтра вечером выкачу новый релиз, где добавлю этот фильтр и ещё пару фич.

Цитата:
Постепенно доходит.
Мне кажется, что тут главное понять, что SS по своей идеологии близок с JS, т.е. директивы повторяют конструкции JS (а иногда и улучшают): циклы, переменные (тут правда стоит отметить, что в отличии от var в JS, в SS блочная область видимости), условия, замыкания и т.д.
__________________
kobezzza
code monkey

Последний раз редактировалось kobezzza, 07.02.2015 в 16:18.
Ответить с цитированием
  #470 (permalink)  
Старый 07.02.2015, 16:25
sinistral
Посмотреть профиль Найти все сообщения от melky
 
Регистрация: 28.03.2011
Сообщений: 5,418

Сообщение от kobezzza
Ну он наверное имел ввиду работу с результатом работы шаблона, а SS как раз умеет формировать DocumentFragment, а не только строку.
угумс. только до меня не доходит, как тогда передавать данные
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
express-snakeskin - view через snakeskin для express melky Ваши сайты и скрипты 5 10.06.2014 11:35