Цитата:
with obj1
.prop = 2; // магическая точка очень кстати
end with
Цитата:
|
Цитата:
Цитата:
По умолчанию раньше у всех прототипов где бы они не были объявлены всегда был был глобальный контекст (относительно шаблона). В новой же версии контекст по умолчанию привязан к родительскому (как я описывал постами выше). Ща пью кофе, делаю финальные тесты, рефакторинг и обновляю доку:) К вечеру всё буит наверно |
интересно глянуть. сейчас демо с гитхаба ругается
Snakeskin Error: Missing closing or opening tag in the template, node: (class: undefined, id: templates)")! теги все там закрыты, так что хз чего он хочет |
Цитата:
UPD: не были закомитены собранные файлы, теперь всё работает |
Фух, вроде закончил работу на версией 2.3. На обновление доки сегодня наверно уже сил не хватит, отложу на завтра:)
Итак, почти 5 полных дней (рабочих :)) я потратил на разработку новой версии Snakeskin, что было сделано: 1) Полностью переписана часть, отвечающая за анализ и обработку параметров директив: В прошлых версиях директива with работала крайне криво и только на выводе значений (теперь её поддерживаю почти все директивы), т.е. конструкция ниже не работала бы
{with myObj}
{a + b}
{end}
Теперь же with работает ровно так, как от него этого ожидают, т.е. можно использовать сложные выражения и т.д., а также появилась возможность указать модификаторы, проще показать:
{with myObj}
{with foo}
{with deep}
{a} /// эквивалентно myObj.foo.deep.a
{#a} /// эквивалентно myObj.foo.a
{#2a} /// эквивалентно myObj.a
{#3a} /// эквивалентно a
{@a} /// эквивалентно a
{@@a} /// доступ к супер-глобальной переменной, об этом чуть позже
{end}
{end}
{end}
Как видите, теперь появилась возможность точно указывать контекст поиска: модификатор # указывает на то, что искать свойство нужно на один with блок вверх, а если после решётки указать цифру, например, #2, то на два блока вверх и т.д. Следует заметить, что # - это более короткая запись #1. Модификатор @ позволяет сказать, что поиск значения объекта должен осуществляться вне блоков with. Также теперь в выражениях появилась возможность использовать составные фильтры, т.е.
/// Для переменной a и b отдельно применяется фильтр ucfirst,
/// а затем ко всему выражению фильтр truncate
{(a|ucfirst) + (b|ucfirst) |truncate}
Чтобы ввести составной фильтр, нужно просто взять его декларацию в круглые скобки, как это сделано на примере выше. Как и с глобальными фильтрами можно использовать несколько фильтров подряд, а также передавать значения в фильтр:
{(a|ucfirst|remove 'foo') + (b|ucfirst) |truncate}
{e = ('foo'|ucfirst)}
В догонку к фильтрам: исправлена ошибка при использовании побитового ИЛИ (|), теперь считается, что если после | идёт или цифра или пробел, то это операция ИЛИ, а не фильтр:
{0|1} {0 | 1} /// ИЛИ
{a = 1}
{0| a} {0 | a} /// ИЛИ
{0|round} {0 |round} /// Фильтр
2) Супер-глобальные переменные. На самом деле эта фича существовала уже давно, но сейчас я её немного облагородил. Если вкратце:
/// Объявляем супер глобальную переменную
{a = 1}
{template foo()}
{@a} /// Получаем значение супер глобальной переменной
{with ...}
{@@a} /// Получаем значение супер глобальной переменной внутри
{end}
// Объявляем супер глобальную переменную внутри шаблона
{@e = 1}
{end}
Такие переменные хранятся в Snakeskin.Vars. 3) Директива var. Эта директива позволяет объявлять переменные внутри шаблона. В отличии от констант переменные могут менять значение в ходе программы, но не могут явно переопределятся в дочернем шаблоне, как константы.
{template foo()}
{var a = 1}
{a = 2}
{a = 3}
{end}
4) Директивы циклов: for, while, repeat/until
{for var i = 0; i < 10; i++}
...
{end}
{var i = 100}
{while i--}
...
{end}
{var i = 100}
{repeat}
...
{until i--}
4) Статичный scope для proto Как я уже писал выше: теперь при декларации proto блока, он наследует родительский scope. 5) Сахарок: Для директивы data добавлена короткая форма записи: {{ ... }}; Теперь функцииям-шаблонам в JS ставится свойство name. Внутри шаблона доступны локальные переменные TPL_NAME и PARENT_TPL_NAME. В остальном исправления множества ошибок и т.д. ЗЫ: И смешно и грустно: первая версия шаблонки была ~400 строк, а эта уже почти 2.7к |
Зарелизил версию 2.3.4 с исправлением некоторых ошибок.
Также теперь проект добавлен в репозитарий npm, следовательно для простой установки можно сделать: npm install -g snakeskin Обновилось консольное АПИ. Подробности в доке на гитхабе или в консольке -h. Обновилась документация на гитхабе. Тем кто юзает продукты JetBrains теперь можно оч просто настроить file watcher для шаблона. Поиграться с шаблоном можно здесь: http://jsfiddle.net/NAPWB |
Цитата:
|
Цитата:
|
правильно понимаю, что это http://jsfiddle.net/NAPWB/3/ должно работать?
|
Цитата:
UPD: поправил, бага наитупейшия была, а воспроизводилось только на пробельных отступах :) Спс за репорт! |
| Часовой пояс GMT +3, время: 11:46. |