当拖动并输入<div class="upload-cont">
时,颜色会从边框和文字的灰色变为黑色,而当<span class="add-text">
变为灰色时,颜色会变为灰色。
CSS:
.upload-cont{
cursor:pointer;
margin-left:130px;
display:inline-block;
border:2px dashed #a8a8a8;
max-width:220px;
max-height:180px;
min-width:220px;
min-height:180px;
position:relative;
border-radius:3px;
}
.add-text{
display:block;
font-size:10px;
font-weight:bold;
color:#999;
word-wrap:break-word;
text-align:center;
width:100px;
top:37%;
left:25%;
position:absolute;
}
.add-text:hover{ color:black; }
HTML:
<div class="upload-cont">
<span class="add-text">
Click to add or<br/>
Drag and drop image here
</span>
</div>
Jquery的:
$(document).ready(function () {
$(".upload-cont,.add-text").on('dragenter', function (e) {
$(".upload-cont").css({
"border": "2px dashed black"
});
$(".add-text").css({
"color": "black"
});
});
$(".upload-cont").on('dragleave', function (e) {
$(".upload-cont").css("border", "2px dashed #a8a8a8");
$(".add-text").css({
"color": "#a8a8a8"
});
});
});
输入<span class="add-text">
检查此jsfiddle: http://jsfiddle.net/rpABs/
提前致谢
答案 0 :(得分:7)
使用dragover
代替dragenter
,因为当您输入子元素时会触发dragleave
$(".upload-cont,.add-text").on('dragover', function (e) {
$(".upload-cont").css({
"border": "2px dashed black"
});
$(".add-text").css({
"color": "black"
});
});
$(".upload-cont").on('dragleave', function (e) {
$(".upload-cont").css("border", "2px dashed #a8a8a8");
$(".add-text").css({
"color": "#a8a8a8"
});
});
答案 1 :(得分:2)
dragover
事件在您拖动时不断触发,因此我不是该解决方案的粉丝。我写了一个名为Dragster的小图书馆给了我更好的enter
&amp; leave
事件。
答案 2 :(得分:0)
显然,这个问题比我想的要多,因为我发现至少5个与同一主题相关的问题(我将回答与该问题相关的所有问题)。
与“ mouseover”不同,事件“ dragover”和“ dragleave”不会将子元素视为一个整体,因此,每次鼠标经过任何一个子元素时,都会触发“ dragleave”。
考虑文件上传,我创建了一个小部件,该小部件允许:
问题:由于所有形式的输入和图像都在DIV子级中,因此即使没有离开虚线,也会触发“ dragleave”。不能使用“指针事件:无”属性,因为方法3和4需要触发“ onchange”事件。
解决方案?重叠的DIV,当鼠标进入时会覆盖所有放置容器,唯一的一个子元素带有“指针事件:无”。
结构:
然后,当鼠标通过将元素拖动到#drop-area进入时,立即在前面显示#drop-pupup,随后事件将在该div上而不是初始接收者上。
这是JS / jQuery代码。我自由离开了PoC,所以不要在我迷路的时候一直迷路。
jQuery(document).on('dragover', '#drop-area', function(event) {
event.preventDefault();
event.stopPropagation();
jQuery('#drop-popup').css('display','block');
});
jQuery(document).on('dragover dragleave drop', '#drop-popup', function(event) {
event.preventDefault();
event.stopPropagation();
console.log(event.type);
// layout and drop events
if ( event.type == 'dragover') {
jQuery('#drop-popup').css('display','block');
}
else {
jQuery('#drop-popup').css('display','none');
if ( event.type == 'drop' ) {
// do what you want to do
// for files: use event.originalEvent.dataTransfer.files
// for web dragged elements: use event.originalEvent.dataTransfer.getData('Text') and CURL to capture
}
}
});
body {
background: #ffffff;
margin: 0px;
font-family: sans-serif;
}
#drop-container {
margin: 100px 10%; /* for online testing purposes only */
width: 80%; /* for jsfiddle purposes only */
display: block;
float: left;
overflow: hidden;
box-sizing: content-box;
position: relative; /* needed to use absolute on #drop-popup */
border-radius: 5px;
text-align: center;
cursor: default;
border: 2px dashed #000000;
}
#drop-area {
display: block;
float: left;
padding: 10px;
width: 100%;
}
#drop-popup {
display: none;
box-sizing: content-box;
position: absolute;
width: 100%;
top: 0;
left: 0;
background: linear-gradient(to BOTTOM, rgba(245, 245, 245, 1) , rgba(245, 245, 245, 0));
height: 512px;
padding: 20px;
z-index: 20;
}
#drop-popup > p {
pointer-events: none;
}
<html>
<head>
<title>Drag and Drop</title>
</head>
<body>
<div id="drop-container">
<div id="drop-area">
<p>Child paragraph content inside drop area saying "drop a file or an image in the dashed area"</p>
<div>This is a child div No. 1</div>
<div>This is a child div No. 2</div>
</div>
<div id="drop-popup">
<p>This DIV will cover all childs on main DIV dropover event and current P tag is the only one with CSS "pointer-events: none;"</p>
</div>
</div>
<script src="https://code.jquery.com/jquery-3.4.1.min.js" type="text/javascript"></script>
</body>
<html>
关于jQuery“ on”,将其与div id一起使用,这样您就可以启动事件触发器,从而隐藏“ uploading box”。
最后,相对于“ dragoner”,我更喜欢使用“ dragover”,因为它具有较小的延迟(毫秒),有利于性能 (https://developer.mozilla.org/en-US/docs/Web/API/Document/dragover_event)。