<html> <head> <title>region</title> <style> body { margin: 0; padding: 0; } #selectContainer { position: relative; 400px; /* 演示宽高与位置 */ height: 400px; top: 200px; left: 200px; border: 1px solid #eee; overflow: hidden; overflow-x: auto; } .fileDiv { display: inline-block; 100px; height: 100px; margin: 24px; background-color: #0082CC; float: left; } .wrapper { 1080px; } </style> </head> <body> <div id="selectContainer"> <div class="wrapper"> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> <div class="fileDiv"></div> </div> </div> </body> </html> <script> (function () { var mouseStopId; var mouseOn = false; var startX = 0; var startY = 0; // 获取容器元素 var selectContainer = document.getElementById('selectContainer'); selectContainer.onmousedown = function (e) { clearEventBubble(e); if (e.buttons !== 1 || e.which !== 1) return; mouseStopId = setTimeout(function () { mouseOn = true; // 调整坐标原点为容器左上角 startX = e.clientX - selectContainer.offsetLeft + selectContainer.scrollLeft; startY = e.clientY - selectContainer.offsetTop + selectContainer.scrollTop; var selDiv = document.createElement('div'); selDiv.style.cssText = 'position:absolute;0;height:0;margin:0;padding:0;border:1px dashed #eee;background-color:#aaa;z-index:1000;opacity:0.6;display:none;'; selDiv.id = 'selectDiv'; // 添加框选元素到容器内 document.getElementById('selectContainer').appendChild(selDiv); selDiv.style.left = startX + 'px'; selDiv.style.top = startY + 'px'; }, 20); document.onmousemove = function (e) { if (!mouseOn) return; clearEventBubble(e); var selectContainer = document.getElementById('selectContainer'); var _x = e.clientX - selectContainer.offsetLeft + selectContainer.scrollLeft; var _y = e.clientY - selectContainer.offsetTop + selectContainer.scrollTop; var _H = selectContainer.offsetWidth // 鼠标移动超出容器内部,进行相应的处理 // 向右拖拽 if (e.clientX > selectContainer.offsetLeft + selectContainer.offsetWidth) { let maxLeft = selectContainer.scrollWidth - selectContainer.offsetWidth let step = selectContainer.scrollLeft + 20 if (step >= maxLeft) { selectContainer.scrollLeft = maxLeft } else { selectContainer.scrollLeft = step } } // 向左拖拽 if (e.clientX < selectContainer.offsetLeft) { let minLeft = 0 let step = selectContainer.scrollLeft - 20 if (step <= minLeft) { selectContainer.scrollLeft = minLeft } else { selectContainer.scrollLeft = step } } var selDiv = document.getElementById('selectDiv'); selDiv.style.display = 'block'; selDiv.style.left = Math.min(_x, startX) + 'px'; selDiv.style.top = Math.min(_y, startY) + 'px'; if ((Math.min(_x, startX) + Math.abs(_x - startX)) <= selectContainer.scrollWidth) { selDiv.style.width = Math.abs(_x - startX) + 'px'; } selDiv.style.height = Math.abs(_y - startY) + 'px'; }; document.onmouseup = function (e) { if (!mouseOn) return; clearEventBubble(e); var selDiv = document.getElementById('selectDiv'); var fileDivs = document.getElementsByClassName('fileDiv'); var selectedEls = []; var l = selDiv.offsetLeft; var t = selDiv.offsetTop; var w = selDiv.offsetWidth; var h = selDiv.offsetHeight; for (var i = 0; i < fileDivs.length; i++) { var sl = fileDivs[i].offsetWidth + fileDivs[i].offsetLeft; var st = fileDivs[i].offsetHeight + fileDivs[i].offsetTop; if (sl > l && st > t && fileDivs[i].offsetLeft < l + w && fileDivs[i].offsetTop < t + h) { fileDivs[i].style.background = 'red' selectedEls.push(fileDivs[i]); } } console.log(selectedEls); selDiv.style.display = 'none'; mouseOn = false; }; } function clearEventBubble (e) { if (e.stopPropagation) e.stopPropagation(); else e.cancelBubble = true; if (e.preventDefault) e.preventDefault(); else e.returnValue = false; } })(); </script>