gpt4 book ai didi

javascript - IE7 + JavaScript appendChild = 滚动条错误

转载 作者:行者123 更新时间:2023-11-28 18:32:46 24 4
gpt4 key购买 nike

我正在改编在 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>

最佳答案

您遇到了 IE7 scrolling div bug .

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

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

关于第二个问题,你可以position: relative div.scroll 然后用height: 1.5em div包起来如 this jsfiddle 中所示.包装 div 可以根据需要添加定位和 z-indexing:请注意,如果您需要内部元素显示得比包装 div 的其他兄弟元素高,则由于与子元素上的 z 索引与祖先的同级元素。在 IE7 模式和 Chrome 中工作。

(请注意,如果你想让它成为一个内联元素,你可以显示:inline-block它并带有通常的警告——适当的jsfiddle here和IE7修复hack with 缩放*display:inline version here )

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

关于javascript - IE7 + JavaScript appendChild = 滚动条错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13820371/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com