WedX - журнал о программировании и компьютерных науках

Используете встроенный jQuery с шаблонами Handlebars.js?

Я использую Sammy.js для обработки логики маршрутизации/приложений и Handlebars.js для создания шаблонов. Я хотел бы настроить несколько простых событий jQuery, чтобы сделать пользовательский интерфейс динамическим (переключение элементов и т. д.). Например:

$("#availability").click( function(e) {
    console.log("hi2");
    e.preventDefault();
});

В настоящее время я могу сделать это, поместив события jQuery внутри приложения Sammy.js, но это выглядит очень грязно:

this.get('#q=:query', function(context) {
    var query = context.params.query,
    loadOptions =   {
                      type: 'get', 
                      dataType: 'json',
                      data: {query: query},
                      cache: CACHE_ENABLED
                    };

    context.load("search.php", loadOptions)
            .then(function(products) {
                 context.query = query;
                 context.products = products.hits.hits;                         
                 return context;
            })
            .partial('/js/templates/search.hb')
            .replace('body')
            .then( function () {
                $("#availability").click( function(e) {
                    console.log("hi2");
                    e.preventDefault();
                });
            });
});

Есть ли способ инициализировать эти типы событий jQuery внутри самого шаблона Handlebars или с помощью помощника? Я пытался зарегистрировать некоторые пользовательские помощники, но события никогда не запускаются.

Я хотел бы отделить «Логику пользовательского интерфейса» от основной логики приложения, поскольку она загромождает мой основной код Sammy.js и затрудняет его чтение.


Ответы:


1

До сих пор не нашел способ включить встроенный jQuery в шаблон Handlebars, но я нашел лучший способ включить его в приложение Sammy. Я удалил код в Sammy Helper и вызвал его, что помогает убрать беспорядок в основной части приложения.

var app = Sammy("body", function() {

    this.use('Handlebars', 'hb');

    this.helpers({
         jq_clickEvents: function() {
             $("#availability").click( function(e) {
                    console.log("hi2");
                    e.preventDefault();
              });

         }
    });

    this.get('#q=:query', function(context) {
        var query = context.params.query,
        loadOptions =   {
                  type: 'get', 
                  dataType: 'json',
                  data: {query: query},
                  cache: CACHE_ENABLED
                };

         context.load("search.php", loadOptions)
                .then(function(products) {
                    context.query = query;
                    context.products = products.hits.hits;                         
                    return context;
                 })
                .partial('/js/templates/search.hb')
                .replace('body')
                .then('jq_clickEvents');
     });
});
30.07.2012
Новые материалы

Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

Объяснение документов 02: BERT
BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..


Для любых предложений по сайту: [email protected]