页面上的 HTML 垂直可调整大小区域

标签 html css resize vbox hbox

我正在尝试创建类似 This 的页面布局

但我不确定如何实现它。我的意思是;在该页面中,您可以看到页面中有两个区域,您可以使用它们之间的栏调整区域的大小。

谢谢!

最佳答案

是的,这当然是可能的。可能有一个 JQuery 或 MooTools 插件可以做到这一点。否则,我向您展示了一个您可以使用的使用 JQuery 的简单示例。参见 this JSFiddle .

HTML 基本上是这样的:

<div id="left">Left column!</div>
<div id="verticalresizer">&nbsp;</div>
<div id="right">Right column!</div>​

然后它们是绝对定位的(为简单起见,从示例中删除了额外的 CSS):

html, body { 
    height: 100%; 
}

#left { 
    width: 200px; /* default starting width */
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
}
#right { 
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 204px; /* width of left col + 4 pixel wide resizer */
}
#verticalresizer { 
    background-color: black; /* so it can be seen */
    width: 4px;
    height: 100%;
    cursor: col-resize;
    position: absolute;
    top: 0;
    left: 200px; /* width of left col */
    bottom: 0;
}

然后是 JavaScript。先解释一下。几乎所有代码都会监听用户是否点击了垂直缩放器。一旦发生这种情况,它就会监听鼠标的移动。每次鼠标移动时,相应地调整列的大小并将 slider 保持在鼠标下方。当用户松开鼠标 (mouseup) 时,停止收听/调整大小。

var left = 200; // starting left col width
var isClicked = false;
var startX = 200; // starting horizontal position of resizer bar
var isMouseDown = false;

// attach listeners to the document itself
$(document).mousedown(function() {
    isMouseDown = true;
}).mouseup(function() {
    isMouseDown = false;
}).mousemove( function(event) {
    if (isClicked && isMouseDown) {
        var newX = event.pageX;

        if (startX != newX) {
            left += (newX - startX);
            if (left < 0) {
                left = 0; // keep from moving the slider beyond the left edge of the screen
                newX = 0;
            }
            setWidthOfLeftColumn( left );
            startX = newX;
        }
    }
});

// attach click listeners to the resizer slider
$("#verticalresizer").mousedown( function(event) {
    isClicked = true;
    startX = event.pageX;
}).mouseup( function (event) {
    isClicked = false;  
});

// function to resize everything
function setWidthOfLeftColumn( value ) {
    $("#left").css("width", "" + left + "px");
     $("#right").css("left", "" + (left + 4) + "px");
     $("#verticalresizer").css("left", "" + left + "px");
 }

关于页面上的 HTML 垂直可调整大小区域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12171215/

相关文章:

javascript - 如何获取内部 JSON 的名称

html - 使用 css 将具有百分比宽度和高度的 div 元素居中

css - <th> 上的边界半径。没有边界舍入

.net - 为 Listview 列实现一个很好的自动调整大小机制?

html - 将鼠标悬停在列表元素上时更改 div 中的文本

javascript - JQuery Columnizer 在一行中有几个 Columnizer 对象。横向扩展...如何?

javascript - 如何让一个div适合100%的手机屏幕

jquery - 隐藏菜单直到悬停框

java - 使用 Java JAI 裁剪、调整大小和保存图像

java - 如何在不闪烁的情况下调整 Swing JWindow 的大小?