Показать сообщение отдельно
  #1 (permalink)  
Старый 16.05.2017, 17:59
Интересующийся
Отправить личное сообщение для TyronNIKO Посмотреть профиль Найти все сообщения от TyronNIKO
 
Регистрация: 16.05.2017
Сообщений: 10

Список при смене языка перестал изменятся
Добрый день! Дали в работу сайт с JS сгенерированом на CofeeScript 1.9.2
Я в JS не силен, сразу говорю.
После изменения структуры расположения страниц в каталоге перестал меняться язык выпадающего меню (в остальном никаких проблем).
Сам код исполняющий скрипт
dropStreetsRus =[большой массив адресов]

  changeLanguage = function() {
    var OthBtn, SafBtn, changeDropDowns, href, setAttr;
    SafBtn = $("#Safari-lang");
    OthBtn = $("#Other-lang");
    href = $(location).attr('href');
    $.getScript("/assets/js/min/detect-min.js", function() {
      var user;
      user = detect.parse(navigator.userAgent);
      if (user.browser.family === 'Safari') {
        $('#Safari-lang').addClass('is-active');
        return $('.experience').addClass('is-Safari');
      } else {
        return $('#Other-lang').addClass('is-active');
      }
    });
    setAttr = function(href) {
      SafBtn.attr('href', href);
      return OthBtn.attr('href', href);
    };
    changeDropDowns = function() {
      dropStreets = dropStreetsRus;
      dropTrafficGeneral = dropTrafficGeneralRus;
      dropTrafficK1 = dropTrafficK1Rus;
      return dropTrafficK2 = dropTrafficK2Rus;
    };
    if (href.indexOf('/rus/') > -1) {
      setAttr(href.replace('/rus', ''));
    } else {
      setAttr(href.splice(href.indexOf('/', 8), 0, '/rus'));
    }
    update_list('#dropdown-group-street', dropStreets);	
  };

  update_list = function(identificator, updater) {
    $(identificator + ' ul li').remove();
    $.each(updater, function(index, updaterValue) {
      $(identificator + ' ul').append('<li class = "someClass">' + updaterValue + '</li>');
    });
  };

  $(document).on('click', '.btn-group .dropdown-menu li', function(e) {
    var btn, btnGroup;
    e.preventDefault();
    btnGroup = $(this).parents('.btn-group');
    if (!($(this).hasClass('disable'))) {
      btn = btnGroup.find('.btn-dropdown');
      btn.addClass('dropdown-selected');
      btn.text($(this).text());
      btn.append('<span class = "caret"> </span>');
      btn.removeClass('dropdown-alert');
      if (btnGroup.is('#dropdown-group-street')) {
        update_list('#dropdown-group-house', dropHouses[$('#dropdown-group-street li').index(this)]);
    }
  });


Выделил из файлы-скрипта основные моменты, которые, на мой взгляд, имеют отношение к этой функции.
Если чего то не хватает - могу пошуршать код.
Ответить с цитированием