Оптимизация моего JavaScript с помощью функции - PullRequest
1 голос
/ 05 мая 2010

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

только с одной парой выбора / идентификатора это работает нормально, но у меня есть кратные значения, и единственное, что меняется, - это идентификатор выбора и ввода. На самом деле только конечные изменения, все входы начинаются с featredproductid все идентификаторы начинаются с recipesproduct, а затем оба заканчиваются категорией.

я знаю, что перечислять это снова и снова для каждой категории - это не способ сделать это. я думаю, что мне нужно сделать массив категорий var cats = ['оливковое масло', "зерна", "макароны"] а затем использовать функцию forEach? может быть?

вот неуклюжий код

window.addEvent('domready', function() {
    $('recipesproductoliveoil').addEvent('change', function(e){
       pidselected = this.options[this.selectedIndex].getProperty('value') ;
   $("featuredproductidoliveoil").setProperties({
       value: pidselected}); ;
    });
       $('recipesproductgrains').addEvent('change', function(e){
           pidselected = this.options[this.selectedIndex].getProperty('value') ;
       $("featuredproductidgrains").setProperties({
           value: pidselected}); ;
        });
      $('recipesproductpasta').addEvent('change', function(e){
          pidselected = this.options[this.selectedIndex].getProperty('value') ;
      $("featuredproductidpasta").setProperties({
          value: pidselected}); ;
       });
    $('recipesproductpantry').addEvent('change', function(e){
        pidselected = this.options[this.selectedIndex].getProperty('value') ;
    $("featuredproductidpantry").setProperties({
        value: pidselected}); ;
     });

});

Имейте в виду, что это Mootools 1.1 (нет, я не могу обновить его извините). я уверен, что это что-то базовое, что-то, что у меня, кажется, обволакивает мой мозг. но я совершенно уверен, что делать это, как указано выше, не очень хорошо ...

Ответы [ 2 ]

1 голос
/ 06 мая 2010

Ты рядом. Вот как вы могли бы это сделать:

var cats = ['oliveoil', 'grains', 'pasta'];
for (i in cats) {
    addChangeFunction(cats[i]);
}

function addChangeFunction(name) {
    $('recipesproduct' + name).addEvent('change', function(e) {
        pidselected = this.options[this.selectedIndex].getProperty('value');
        $('featuredproductid' + name).setProperties({
            value: pidselected
        });
    });
}
0 голосов
/ 06 мая 2010

Как-то так может помочь:

 function bindSelectFeature(select, featured) {
    $(select).addEvent('change', function(e){
        pidselected = this.options[this.selectedIndex].getProperty('value') ;
        $(featured).setProperties({
          value: pidselected
        });
     });
  });
  bindSelectFeature('recipesproductpasta','featuredproductidpasta');
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...