我希望div
在 ipad 上可以滚动,但我不希望在桌面浏览器上看到滚动条,这可能吗?溢出-x:滚动,但滚动条是不可见的?保留滚动功能,但删除滚动条。或者是否可以使用 adiv
来覆盖滚动条?
问问题
566 次
2 回答
0
你得到滚动条的宽度:
var scrollwdth = document.getElementById("scrolldiv").clientWidth;
然后将 textarea 插入到另一个 div 中,该 div 充当框架,并设置如下:
document.getElementById("frame").style.width = scrollwdth + "px";
html是这样的:
<div id="frame">
<div id="scrolldiv"></div>
</div>
而且,非常重要的是,“框架”已经overflow-y:hidden;
使滚动条不可见。
于 2012-12-01T11:54:28.543 回答
0
请在此处检查提琴手代码。
使用下面的代码获取滚动条宽度(从这里引用)
function getScrollBarSize () {
var inner = document.createElement('p');
inner.style.width = "100%";
inner.style.height = "100%";
var outer = document.createElement('div');
outer.style.position = "absolute";
outer.style.top = "0px";
outer.style.left = "0px";
outer.style.visibility = "hidden";
outer.style.width = "100px";
outer.style.height = "100px";
outer.style.overflow = "hidden";
outer.appendChild (inner);
document.body.appendChild (outer);
var w1 = inner.offsetWidth;
var h1 = inner.offsetHeight;
outer.style.overflow = 'scroll';
var w2 = inner.offsetWidth;
var h2 = inner.offsetHeight;
if (w1 == w2) w2 = outer.clientWidth;
if (h1 == h2) h2 = outer.clientHeight;
document.body.removeChild (outer);
return [(w1 - w2),(h1 - h2)];
};
将宽度设置为内部 div,如下所示:
$(document).ready(function() {
$(".innerDiv").width($(".outerDiv").width() + getScrollBarSize()[0]);
});
还有一个链接给出了以 jquery 和非 jquery 方式计算滚动条宽度和高度的实现。
于 2012-12-01T12:47:40.047 回答