Браузер Android не учитывает переполнение CSS

Я работаю с клиентом, который хотел бы, чтобы часть его интерфейса имела несколько настраиваемый метод прокрутки. Они не• чтобы обычные полосы прокрутки были видны; они хотят, чтобы пользователи настольных компьютеров / ноутбуков прокручивали с помощью колесика мыши / сенсорной панели, а мобильные пользователи - прокручивали пальцем. Они также хотят, чтобы графика со стрелкой вверх и стрелкой вниз предоставляла альтернативный метод прокрутки, а также чтобы было понятно пользователю, что прокрутка возможна (поскольку фактические полосы прокрутки скрыты). Клиент настроен на этот метод прокрутки.

Я собрал некоторый код, который работает на всех комбинациях устройства / браузера, которые япопробовал, кроме Android'афондовый браузер. Я подтвердил эту проблему со следующими конфигурациями:

Android 4.1.2 (эмулятор)Android 4.2.2 (актуальное устройство)Android 4.2.2 (эмулятор)Android 4.3 (эмулятор)

Эта проблемане присутствует на Android 4.4.2 (эмулятор), хотя.

Для упрощения этого вопроса ям, не включая графику стрелок вверх и вниз и сопутствующую логику.

Вот'с кодом (jsFiddle demo):



  
    
    Demo
    
      #side_nav, .category {
        position: absolute;
      }

      #side_nav {
        -webkit-user-select: none;
      }

      .category {
        display: none; /* Will be shown when user clicks on an option */
        top: 0;
        left: 150px;
      }

      .ul_wrapper, .ul_wrapper ul {
        width: 125px;
        height: 242px;
      }

      .ul_wrapper {
        background: #ccc;
        border: 3px solid #000;
        border-radius: 6px;
        text-align: center;
        overflow: hidden;
      }

      ul {
        margin: 0;
        padding: 0;
        list-style: none;
        overflow-y: scroll;
      }

      li {
        padding-top: 10px;
      }

      li:last-child {
        padding-bottom: 10px;
      }

      span {
        display: inline-block;
        width: 100px;
        height: 100px;
        border: 3px solid #999;
        border-radius: 6px;
        cursor: pointer;
      }

      #chosen_option {
        float: left;
        margin-left: 150px;
      }
    
  
  
    
      
        
          
            <span>Option 1</span>
            
              
                
                  <span>Option 1a</span>
                  <span>Option 1b</span>
                  <span>Option 1c</span>
                
              
            
          
          
            <span>Option 2</span>
            
              
                
                  <span>Option 2a</span>
                  <span>Option 2b</span>
                
              
            
          
          
            <span>Option 3</span>
            
              
                
                  <span>Option 3a</span>
                
              
            
          
        
      
    

    

    
    
      function get_scrollbar_width() {
        var div, body, W = window.browserScrollbarWidth;
        if (W === undefined) {
          body = document.body, div = document.createElement('div');
          div.innerHTML = '';
          div = div.firstChild;
          body.appendChild(div);
          W = window.browserScrollbarWidth = div.offsetWidth - div.clientWidth;
          body.removeChild(div);
        }
        return W;
      }

      var scrollbar_width = get_scrollbar_width();

      $('#side_nav ul').css({
        'padding-right': scrollbar_width,
        'margin-left': scrollbar_width / 2
      });

      $('span').on('click', function(event) {
        event.stopPropagation(); // Prevent $('html').click(); from triggering

        var parent_li = $(this).parent();
        var child_category = parent_li.children('.category');

        if (child_category.length) {
          var show_div = false;

          if (child_category.is(':hidden')) {
            show_div = true;
          }

          parent_li.siblings().find('.category:visible').fadeOut();

          if (show_div) {
            child_category.fadeIn();
          }
          else {
            parent_li.find('.category:visible').fadeOut();
          }
        }
        else {
          $('#chosen_option').html('You chose ' + $(this).html().toLowerCase());
          $('.category:visible').fadeOut();
        }
      });

      $('html').click(function() {
        $('.category:visible').fadeOut();
      });
    
  

При нажатии на любой из трех вариантов справа появится второй список параметров. Тем не менее, он никогда не появляется на Android 'Браузер, если вы не удалитеoverflow-y: scroll; отul Правила CSS, но тогда вы больше не можете прокручивать.

Проблема лучше всего иллюстрируется заменойleft: 150px; сleft: 25px; в.category Правила CSS. Когда я делаю это, вот как это выглядит в рабочем браузере:

И вот как это выглядит в Android 'фондовый браузер:

Еще одна вещь, которую я должен отметить, это то, что она работает в Chrome для Android.

Есть ли способ, которым я могу сделать это в Android?с браузером?

Ответы на вопрос(2)

Ваш ответ на вопрос