首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >Android股票浏览器不尊重CSS溢出

Android股票浏览器不尊重CSS溢出
EN

Stack Overflow用户
提问于 2014-01-25 06:56:57
回答 2查看 7K关注 0票数 16

我正在和一个客户一起工作,他希望他们的界面的一部分有一些自定义的滚动方法。他们不希望通常的滚动条可见;他们希望台式机/笔记本电脑用户用鼠标滚轮/触摸板滚动,他们希望移动用户用手指滚动。他们还想要上箭头和下箭头的图形,以提供另一种滚动方法,并使用户明显地看到滚动是可能的(因为实际的滚动条是隐藏的)。客户端就是在这种滚动方法上设置的。

我整理了一些代码,这些代码可以在我尝试过的所有设备/浏览器组合上运行,除了Android的常用浏览器。我已使用以下配置确认此问题:

仿真器Android 4.1.2 (emulator)

  • Android 4.2.2 (实际device)

  • Android 4.2.2 (emulator)

  • Android 4.3 (
  • )

不过,Android 4.4.2 (模拟器)上不存在此问题。

为了保持这个问题的简单性,我不包括上下箭头的图形和相应的逻辑。

下面是代码(jsFiddle demo):

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title>Demo</title>
    <style>
      #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;
      }
    </style>
  </head>
  <body>
    <div id="side_nav">
      <div class="ul_wrapper">
        <ul>
          <li>
            <span>Option 1</span>
            <div class="category">
              <div class="ul_wrapper">
                <ul>
                  <li><span>Option 1a</span></li>
                  <li><span>Option 1b</span></li>
                  <li><span>Option 1c</span></li>
                </ul>
              </div>
            </div>
          </li>
          <li>
            <span>Option 2</span>
            <div class="category">
              <div class="ul_wrapper">
                <ul>
                  <li><span>Option 2a</span></li>
                  <li><span>Option 2b</span></li>
                </ul>
              </div>
            </div>
          </li>
          <li>
            <span>Option 3</span>
            <div class="category">
              <div class="ul_wrapper">
                <ul>
                  <li><span>Option 3a</span></li>
                </ul>
              </div>
            </div>
          </li>
        </ul>
      </div>
    </div>

    <div id="chosen_option"></div>

    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
    <script>
      function get_scrollbar_width() {
        var div, body, W = window.browserScrollbarWidth;
        if (W === undefined) {
          body = document.body, div = document.createElement('div');
          div.innerHTML = '<div style="width: 50px; height: 50px; position: absolute; left: -100px; top: -100px; overflow: auto;"><div style="width: 1px; height: 100px;"></div></div>';
          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();
      });
    </script>
  </body>
</html>

当您点击这三个选项中的任何一个时,第二个选项列表应该会出现在右侧。然而,除非你将overflow-y: scroll;ul CSS规则中删除,否则它永远不会出现在安卓的普通浏览器上,但之后你就不能再滚动了。

.category CSS规则中用left: 25px;替换left: 150px;就能很好地说明这个问题。当我这样做时,它在工作的浏览器中看起来是这样的:

这是它在Android的普通浏览器中的样子:

我应该注意的另一件事是,它可以在Android版的Chrome上运行。

有没有办法在安卓的普通浏览器中实现这一点?

EN

回答 2

Stack Overflow用户

发布于 2014-01-30 00:40:33

我对现货的姜饼Android浏览器有一些问题。它根本不能很好地处理溢出的CSS属性。为了在浏览器上启用滚动功能,我必须将溢出("scroll“或"auto")仅应用于BODY容器。

票数 2
EN

Stack Overflow用户

发布于 2014-01-30 00:38:40

我相信Android股票浏览器不支持特定于x/y的溢出属性。启用overflow,然后为overflow-x禁用它,而不是启用overflow-y。示例:

代码语言:javascript
复制
ul {
    margin: 0;
    padding: 0;
    list-style: none;
    overflow-y: scroll;
}

应该变成:

代码语言:javascript
复制
ul {
    margin: 0;
    padding: 0;
    list-style: none;
    overflow: scroll;
    overflow-x: visible;
}

通常我会使用auto而不是scroll,所以如果不需要的话,滚动条就不会显示出来。此外,也许在您的情况下overflow-x: hidden;更可取。基本上,这也会将您想要的overflow-y属性应用于overflow-x,但通常这比规则被完全忽略更可取。对于支持特定于轴的溢出的浏览器,用户不会知道其中的区别。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21344015

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档