实现侧边栏动态调整宽度效果——简易做法
创始人
2024-11-11 03:09:14

拖拽两个贴贴的div

HTML结构

                   Grid.js 表格                
你可以不用假装
12321

核心JS代码

let control = document.querySelector(".item-right-control"); let box = document.querySelector(".item-right"); let explain = document.querySelector(".text"); control.addEventListener("mousedown", (e) => {   document.body.style.userSelect = "none";   document.addEventListener("mousemove", onMouseMove);   document.addEventListener("mouseup", onMouseUp); }); function onMouseMove(e) {   if (window.innerWidth - e.screenX >= 300 && window.innerWidth - e.screenX <= 1200) {     box.style.width = box.offsetWidth + (box.offsetLeft - e.screenX) + "px";   } } function onMouseUp() {   document.body.style.userSelect = "auto";   document.removeEventListener("mousemove", onMouseMove);   document.removeEventListener("mouseup", onMouseUp); } 

完整JS代码

let control = document.querySelector(".item-right-control"); let box = document.querySelector(".item-right"); let explain = document.querySelector(".text"); control.addEventListener("mousedown", (e) => {   document.body.style.userSelect = "none";   explain.innerHTML = `     需要改变宽度的盒子距离最左侧屏幕的距离:${box.offsetLeft}
盒子的宽度:${box.offsetWidth}
`; document.addEventListener("mousemove", onMouseMove); document.addEventListener("mouseup", onMouseUp); }); explain.innerHTML = ` 需要改变宽度的盒子距离最左侧屏幕的距离:${box.offsetLeft}
盒子的宽度:${box.offsetWidth}
`; function onMouseMove(e) { explain.innerHTML = ` 需要改变宽度的盒子距离最左侧屏幕的距离:${box.offsetLeft}
盒子的宽度:${box.offsetWidth}
盒子改变后的宽度:${box.offsetWidth + box.offsetLeft - e.screenX}
鼠标相较于盒子控件的距离:${box.offsetLeft - e.screenX}
视口宽度:${window.innerWidth}
是否可以拖动:${window.innerWidth - box.offsetLeft >= 300} `; if (window.innerWidth - e.screenX >= 300 && window.innerWidth - e.screenX <= 1200) { box.style.width = box.offsetWidth + (box.offsetLeft - e.screenX) + "px"; } } function onMouseUp() { document.body.style.userSelect = "auto"; document.removeEventListener("mousemove", onMouseMove); document.removeEventListener("mouseup", onMouseUp); }

相关内容

热门资讯

裸辞做“一人公司”,我后悔了 去年这个时候,一位以色列程序员正在东南亚旅行。他顺手把一个在脑子里转了很久的想法做成了产品,一个让任...
南京建成国内首个Pre-6G试... 4月21日,2026全球6G技术与产业生态大会在南京开幕。全息互动技术展台前,一名远在北京的工作人员...
超梵求职受邀参加“2025抖音... 超梵求职受邀参加“2025抖音巨量引擎成人教育行业生态大会”,探讨分享优质内容传播,服务万千学员。 ...
摩托罗拉Razr 2026(R... IT之家 4 月 22 日消息,摩托罗拉宣布新一代 Razr 折叠手机将于 4 月 29 日在美国发...
库克卸任,特纳斯领航:苹果新纪... 苹果首席执行官蒂姆·库克将卸任,硬件工程主管约翰·特纳斯将接任,苹果公司今天宣布此事。 库克将在夏季...