1

我正在修改 StackOverflow 上的一个示例,用于替换 IE7 上不支持一些不错的 CSS 布局的“选择”组件。该示例缺少滚动条,因此我添加了一个固定大小的 div,这样滚动条就会出现并且组件几乎完整。

我的问题:

1 - 在 IE7(IE9 兼容模式)上不显示滚动条。有什么解决办法吗?

2 - 如何将“div”定位在该位置但保持在其他组件的前面,而不是占据其全尺寸?

我在 jsfiddle 上的代码/html:

http://jsfiddle.net/mbarni/nTYWA/ (运行为“无包装(头部)”)

内联代码/html:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
  <style type="text/css">
    body {
      font: 80% 'Quicksand-Regular', Verdana, Geneva, sans-serif;
    }
    select {
      display: block;
      margin: 0 0 10px;
      width: 300px;
    }
    select.replaced {
      width: 1px;
      position: absolute;
      left: -999em;
    }
    ul.selectReplacement {
      background: #10194B;
      margin: 0 0 10px;
      padding: 0;
      height: 1.65em;
      width: 300px;
      position: relative;
      z-index: 1000;
    }
    ul.selectFocused {
      background: #10194B;
    }
    ul.selectReplacement li {
      background: #09C;
      color: #fff;
      cursor: pointer;
      display: none;
      font-size: 11px;
      line-height: 1.7em;
      list-style: none;
      margin: 0;
      padding: 1px 12px;
      width: 276px;
    }
    ul.selectOpen li {
      display: block;
    }
    ul.selectReplacement li.selected {
      background: #10194B;
      border-bottom: 1px solid #fff;
      color: #fff;
      display: block;
    }
    ul.selectOpen li.selected {
      background: #10194B;
      border: 0;
      display: block;
    }
    ul.selectOpen li:hover,
    ul.selectOpen li.hover,
    ul.selectOpen li.selected:hover {
      background: #10194B;
      color: #fff;
    }
    div.scroll {
      overflow-y: auto;
      overflow-x: hidden;
      height: 100px;
      width: 300px;
    }
  </style>
  <script type="text/javascript">
    function selectReplacement(obj) {
      obj.className += ' replaced';
      var ul = document.createElement('ul');
      ul.className = 'selectReplacement';
      var div = document.createElement('div');
      div.className = 'scroll';
      div.appendChild(ul);

      var opts = obj.options;
      var selectedOpt = (!obj.selectedIndex) ? 0 : obj.selectedIndex;
      for (var i=0; i<opts.length; i++) {
        var li = document.createElement('li');
        var txt = document.createTextNode(opts[i].text);
        li.appendChild(txt);
        li.selIndex = i;
        li.selectID = obj.id;
        li.onclick = function() {
          selectMe(this);
        };
        if (i == selectedOpt) {
          li.className = 'selected';
          li.onclick = function() {
            this.parentNode.className += ' selectOpen';
            this.onclick = function() {
              selectMe(this);
            };
          };
        }
        if (window.attachEvent) {
          li.onmouseover = function() {
            this.className += ' hover';
          };
          li.onmouseout = function() {
            this.className = 
              this.className.replace(new RegExp(" hover\\b"), '');
          };
        }       
        ul.appendChild(li);
      }
      obj.onfocus = function() {
        ul.className += ' selectFocused';
      };
      obj.onblur = function() {
        ul.className = 'selectReplacement';
      };
      obj.onchange = function() {
        var idx = this.selectedIndex;
        selectMe(ul.childNodes[idx]);
      };
      obj.onkeypress = obj.onchange;
      obj.parentNode.insertBefore(div,obj);
    }
    function selectMe(obj) {
      var lis = obj.parentNode.getElementsByTagName('li');
      for (var i=0; i<lis.length; i++) {
        if (lis[i] != obj) {
          lis[i].className='';
          lis[i].onclick = function() {
            selectMe(this);
          };
       } else {
          setVal(obj.selectID, obj.selIndex);
          obj.className='selected';
          obj.parentNode.className = 
            obj.parentNode.className.replace(new RegExp(" selectOpen\\b"), '');
          obj.onclick = function() {
            obj.parentNode.className += ' selectOpen';
            this.onclick = function() {
              selectMe(this);
            };
          };
        }
      }
    }
    function setVal(objID,val) {
      var obj = document.getElementById(objID);
      obj.selectedIndex = val;
    }
    function setForm() {
      var s = document.getElementsByTagName('select');
      for (var i=0; i<s.length; i++) {
        selectReplacement(s[i]);
      }
    }
    window.onload = function() {
      (document.all && !window.print) ? null : setForm();
    };
  </script>
</head>
<body>  
    <select id="unidade">
        <option value="001">TEST 1</option>
        <option selected value="002">TEST 2</option>
        <option value="003">TEST 3</option>
        <option value="004">TEST 4</option>
        <option value="005">TEST 5</option>
        <option value="006">TEST 6</option>
        <option value="007">TEST 7</option>
        <option value="008">TEST 8</option>
    </select>
</body>
</html>
4

1 回答 1

1

您遇到了IE7 滚动 div 错误

position: relative从中删除ul.selectReplacement,一切正常。已经在 IE9 的 IE7 浏览器模式下在 jsfiddle中进行了测试。

如果您发现需要position: relativeul 元素上的 ,请附加position: relative到包含的 div ( div.scroll),这也可以解决问题(相关的 jsfiddle)。在 chrome 或 IE7 模式下,仅条带相对位置似乎并没有破坏任何东西,但是如果您需要 ul 元素不使用静态模型并且不需要 div 使用静态,则第二种方法也可以正常工作两种情况。

至于第二个问题,您可以position: relativediv.scroll其包装在一个height: 1.5emdiv 中,如此 jsfiddle中所见。包装 div 可以根据需要添加定位和 z-indexing:请注意,如果您需要内部元素看起来比包装 div 的其他兄弟元素更高,则由于 IE 错误相关,您将需要包装上的 z-indexing子元素与祖先元素的 z 索引。在 IE7 模式和 chrome 中工作。

(请注意,如果您想让它成为一个内联元素,您可以display: inline-block使用通常的警告 - 适当的jsfiddle here和 IE7 fix hack with zoomand *display:inline version here

编辑:通过在两个不同高度之间切换 div 来修复以下文本的内联版本:jsfiddle。请注意,这将需要对 ul 和 li 元素的高度/线高进行一些调整,以避免从打开到关闭的高度轻微位移,但基本概念就在那里,尽管方式不优雅(“更好”就是简单地更改 div 的高度属性,或在其他类中隔离高度并仅交换该类)。请注意,必须降低所选元素的高度并移除填充,以便能够将 div 压缩到基本上为单行高度。如果需要,进一步降低某些元素的高度将允许进一​​步压缩滚动 div,即使在关闭状态下也不会出现滚动条。

于 2012-12-11T16:10:50.637 回答