ProDomainer.ru - Клуб Домейнеров  
     

Войти через OpenID
Left Nav Справка ПортфолиоАукцион (39) Календарь Поиск Сообщения за день Все разделы прочитаны Right Nav

Left Container Right Container
 
Старый 09.03.2017, 16:59   #1
Член Клуба ProDomainer.ru
 

Простейший шаблонизатор

На самом деле эта "статья" состоит из одного тега. Тег template.
Поддерживается большинством современных браузеров. Так что в админках уже можно юзать.
Описание.
Фидл с примером.
Пример:
Код HTML:
<table id="table">
    <tbody>
      <template class="row">
      <tr>
        <td class="name"></td>
        <td class="color"></td>
        <td class="sex"></td>
        <td class="legs"></td>
      </tr>
      </template>
    </tbody>
</table>
Ну и простейший ЖС.
Код:
function renderTable(tableSelector,rowSelector,data) {
 var table = document.querySelector(tableSelector);
 var template = table.querySelector(rowSelector);
 for (var i = 0; i < data.length; i += 1) {
   var line = data[i];
   var clone = template.content.cloneNode(true);
   for(var key in line) {
     var selector = '.' + key;
     clone.querySelector(selector).textContent = line[key];
   }
   template.parentNode.appendChild(clone);
 }
}
// вызовем функцию
 var data = [
   { name: 'Pillar', color: 'Ticked', sex: 'Female', legs: 3 },
   { name: 'Hedral', color: 'Tuxedo', sex: 'Male', legs: 4 },
   { name: 'Hedral', color: 'Tuxedo', sex: 'Male', legs: 4 },
 ];
renderTable('#table','.row',data);
По хорошему надо бы немного универсальнее и чище, но за пример сойдет.

В любой ситуации выбор всегда за вами. Вы либо гуляете под дождем, либо просто под ним мокнете.
Mendel вне форума   Ответить с цитированием
Старый 15.03.2017, 19:07   #2
Член Клуба ProDomainer.ru
 

Спецификация активно юзается в современных js-тулзах, типа polymer, vue.js, react итп.

ps также советую посмотреть на спеку Shadow DOM

http://rudevich.com
Александр вне форума   Ответить с цитированием
Старый 17.03.2017, 18:29   #3
Член Клуба ProDomainer.ru
 

Цитата:
Сообщение от Александр Посмотреть сообщение
Shadow DOM
Насколько я помню там тяжело с поддержкой.
Но я даже не о том.
Хочу очень простой шаблонизатор.
Изредка бывает надо сделать что-то динамически, и не хочется тащить за собой тяжелые библиотеки.
А тут всё достаточно просто.
Написать такой вот скрипт на экран кода, прописать основные фичи шаблонизатора (а их всего три - вывести переменную, цикл и условие) - в виде атрибутов data-foreach="переменная", да и скармливать вот это вот одной строчкой даже без жгвери.
Звучит прикольно, но мне конечно же лень. Везде где оно было бы уместно у меня уже всё написано, и переписывать я поленюсь)))

В любой ситуации выбор всегда за вами. Вы либо гуляете под дождем, либо просто под ним мокнете.
Mendel вне форума   Ответить с цитированием
Ответ


Здесь присутствуют: 1 (пользователей: 0 , гостей: 1)
 
Опции темы
Опции просмотра

Ваши права в разделе
BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения
Быстрый переход


Часовой пояс GMT +4, время: 06:09.