让我更具体一点......我不希望DIV在我拖动时调整大小。我想将它拖出来(也许我的光标后面有一条垂直线)当我发布时,它会调整div的大小。
答案 0 :(得分:37)
看一下这个例子
<强> HTML 强>
<div id="sidebar">
<span id="position"></span>
<div id="dragbar"></div>
sidebar
</div>
<div id="main">
main
</div>
<强> jquery的强>
var dragging = false;
$('#dragbar').mousedown(function(e){
e.preventDefault();
dragging = true;
var main = $('#main');
var ghostbar = $('<div>',
{id:'ghostbar',
css: {
height: main.outerHeight(),
top: main.offset().top,
left: main.offset().left
}
}).appendTo('body');
$(document).mousemove(function(e){
ghostbar.css("left",e.pageX+2);
});
});
$(document).mouseup(function(e){
if (dragging)
{
$('#sidebar').css("width",e.pageX+2);
$('#main').css("left",e.pageX+2);
$('#ghostbar').remove();
$(document).unbind('mousemove');
dragging = false;
}
});
http://jsfiddle.net/gaby/Bek9L/1779/
演示这是我在Emulating frame-resize behavior with divs using jQuery without using jQuery UI?
中发布的代码的更改答案 1 :(得分:20)
一直在寻找这个,Gaby非常好的解决方案。虽然我的要求是没有任何绝对元素并且使用百分比而不是像素,所以我已经改变了Gaby的代码以适应这一点(如果有人有兴趣)
<强> CSS 强>
#main{
background-color: BurlyWood;
float: right;
height:200px;
width: 75%;
}
#sidebar{
background-color: IndianRed;
width:25%;
float: left;
height:200px;
overflow-y: hidden;
}
#dragbar{
background-color:black;
height:100%;
float: right;
width: 3px;
cursor: col-resize;
}
#ghostbar{
width:3px;
background-color:#000;
opacity:0.5;
position:absolute;
cursor: col-resize;
z-index:999
}
<强> JS 强>
var i = 0;
var dragging = false;
$('#dragbar').mousedown(function(e){
e.preventDefault();
dragging = true;
var main = $('#main');
var ghostbar = $('<div>',
{id:'ghostbar',
css: {
height: main.outerHeight(),
top: main.offset().top,
left: main.offset().left
}
}).appendTo('body');
$(document).mousemove(function(e){
ghostbar.css("left",e.pageX+2);
});
});
$(document).mouseup(function(e){
if (dragging)
{
var percentage = (e.pageX / window.innerWidth) * 100;
var mainPercentage = 100-percentage;
$('#console').text("side:" + percentage + " main:" + mainPercentage);
$('#sidebar').css("width",percentage + "%");
$('#main').css("width",mainPercentage + "%");
$('#ghostbar').remove();
$(document).unbind('mousemove');
dragging = false;
}
});
答案 2 :(得分:7)
有一种更简单的方法可以实现这一目标。 CSS 3具有resize
属性,以使html元素可调整大小,同时遵循其他CSS属性,如最小/最大宽度等。
.resizeable {
resize: both;
overflow: auto;
border: 2px solid black;
}
答案 3 :(得分:5)
将jQuery UI与ghost选项一起使用:
<强> See working jsFiddle demo: 强>
$( "#resizable" ).resizable({ ghost: true });
答案 4 :(得分:5)
Pure JS
Live Update
CSS Variable
let dragging = 0,
body = document.body,
target = document.getElementById('dragbar');
function clearJSEvents() {
dragging = 0;
body.removeEventListener("mousemove", resize);
body.classList.remove('resizing');
}
function resize(e) {
if (e.pageX > 400 || e.pageX < 200) {
return;
}
body.style.setProperty("--left-width", e.pageX + 'px');
}
target.onmousedown = function(e) {
e.preventDefault();
dragging = 1;
body.addEventListener('mousemove', resize);
body.classList.add('resizing');
};
document.onmouseup = function() {
dragging ? clearJSEvents() : '';
};
body {
--left-width: 300px;
padding: 0;
margin: 0;
}
body.resizing {
cursor: col-resize;
}
#main,
#sidebar,
#dragbar {
top: 0;
height: 100%;
background: white;
position: absolute;
}
#sidebar {
background: #e6e9f0;
width: var(--left-width);
}
#main {
right: 0;
overflow: scroll;
width: calc(100% - var(--left-width));
}
#main section {
margin: 20px auto;
border-radius: 10px;
background: white;
height: 100px;
width: calc(100% - 60px);
transition: 0.3s ease-in-out 0s;
box-shadow: 0px 0px 0px 1px rgba(0, 0, 0, 0.1);
}
#main section:hover {
box-shadow: 0px 3px 25px rgba(0, 0, 0, 0.2), 0px 0px 0px 1px #A8D1FD;
}
#dragbar {
right: 0;
width: 5px;
opacity: 0;
cursor: col-resize;
background: #0099e5;
transition: 0.3s ease-in-out 0s, opacity 0.3s ease-in-out 0s;
}
#dragbar:hover,
body.resizing #dragbar {
opacity: 1;
transition: 0.3s ease-in-out 0s, opacity 0.3s ease-in-out .3s;
}
<body>
<section id="sidebar">
<div id="dragbar"></div>
</section>
<main id="main">
<section></section>
<section></section>
<section></section>
</main>
</body>
答案 5 :(得分:3)
如果没有浮动,这是一种稍微不同的方式:
var dragging = false;
$('#dragbar').mousedown(function(e){
e.preventDefault();
dragging = true;
var side = $('#side');
$(document).mousemove(function(ex){
side.css("width", ex.pageX +2);
});
});
$(document).mouseup(function(e){
if (dragging)
{
$(document).unbind('mousemove');
dragging = false;
}
});
div{
color: #fff;
font-family: Tahoma, Verdana, Segoe, sans-serif;
}
#container{
background-color:#2E4272;
display:flex;
}
#side{
background-color:#4F628E;
width: 300px;
position: relative;
}
#main{
background-color:#7887AB;
z-index: 1;
flex-grow: 1;
}
#dragbar{
background-color:black;
height:100%;
position: absolute;
top: 0;
right: 0;
width: 5px;
cursor: col-resize;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="container">
<div id="side">
Side<br /> Blabla<br /> Blabla<br /> Blabla<br />
<div id="dragbar"></div>
</div>
<div id="main">Dynamically sized content</div>
</div>
答案 6 :(得分:1)
我写了(大部分)这一段时间http://jsfiddle.net/ydTCZ/12/。这是一张桌子,但要让它适应一个div并不难。我向您展示了这一点,因为它提供了创建调整大小效果所需的jQuery的洞察力,从而允许完全自定义以满足您的需求。
答案 7 :(得分:1)
我编辑了第一条评论的解决方案,但是对于块的垂直大小调整
body,html{width:100%;height:100%;padding:0;margin:0;}
.clearfix:after {
content: '';
display: table;
clear: both;
}
#wrapper {
width: 600px;
margin: 50px auto 0 auto;
height: 300px;
background: yellow;
}
#main{
background-color: BurlyWood;
height:40%;
width: 100%;
min-height: 30px;
max-height: calc(100% - 30px);
}
#sidebar{
display: flex;
align-items: flex-end;
background-color: IndianRed;
width:100%;
height:60%;
overflow-y: hidden;
min-height: 30px;
max-height: calc(100% - 30px);
}
#dragbar{
background-color:black;
height:3px;
float: right;
width: 100%;
cursor: row-resize;
}
#ghostbar{
width: 100%;
height: 3px;
background-color:#000;
opacity:0.5;
position:absolute;
cursor: col-resize;
z-index:999}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.0/jquery.min.js"></script>
<div class="clearfix" id="wrapper">
<div id="sidebar">
<span id="position"></span>
<div id="dragbar"></div>
</div>
<div id="main"> </div>
</div>
{{1}}
演示:jsfiddle
答案 8 :(得分:0)
你可以在这里找到一个可调整大小的div,它提供反馈,但只有在你释放后才会重新调整。
答案 9 :(得分:0)
let dragging = 0,
body = document.body,
target = document.getElementById('dragbar');
function clearJSEvents() {
dragging = 0;
body.removeEventListener("mousemove", resize);
body.classList.remove('resizing');
}
function resize(e) {
if (e.pageX > 400 || e.pageX < 200) {
return;
}
body.style.setProperty("--left-width", e.pageX + 'px');
}
target.onmousedown = function(e) {
e.preventDefault();
dragging = 1;
body.addEventListener('mousemove', resize);
body.classList.add('resizing');
};
document.onmouseup = function() {
dragging ? clearJSEvents() : '';
};
body {
--left-width: 300px;
padding: 0;
margin: 0;
}
body.resizing {
cursor: col-resize;
}
#main,
#sidebar,
#dragbar {
top: 0;
height: 100%;
background: white;
position: absolute;
}
#sidebar {
background: #e6e9f0;
width: var(--left-width);
}
#main {
right: 0;
overflow: scroll;
width: calc(100% - var(--left-width));
}
#main section {
margin: 20px auto;
border-radius: 10px;
background: white;
height: 100px;
width: calc(100% - 60px);
transition: 0.3s ease-in-out 0s;
box-shadow: 0px 0px 0px 1px rgba(0, 0, 0, 0.1);
}
#main section:hover {
box-shadow: 0px 3px 25px rgba(0, 0, 0, 0.2), 0px 0px 0px 1px #A8D1FD;
}
#dragbar {
right: 0;
width: 5px;
opacity: 0;
cursor: col-resize;
background: #0099e5;
transition: 0.3s ease-in-out 0s, opacity 0.3s ease-in-out 0s;
}
#dragbar:hover,
body.resizing #dragbar {
opacity: 1;
transition: 0.3s ease-in-out 0s, opacity 0.3s ease-in-out .3s;
}
<body>
<section id="sidebar">
<div id="dragbar"></div>
</section>
<main id="main">
<section></section>
<section></section>
<section></section>
</main>
</body>