JS-拖拽元素放大缩小

效果左右布局,拖拽后,宽度放大缩小

其实自己写也可以,不过还是发现了两个好用的js库,既然不需要自己写,当然是能偷懒就偷懒
1、resizerjs

官网地址:https://github.com/eknowles/resizerjs

复制代码
<!doctype html>
<html>
<head>
  <meta charset="utf-8">
  <title>拖拽</title>
  <style>
    [data-rz-handle] {
      flex: 0 0 6px;
      background-color: rgba(0, 0, 0, 0.9);
    }

    [data-rz-handle] div {
      width: 6px;
      background-color: rgba(0, 0, 0, 0.9);
    }
    .container {
      width: 1200px;
      height: 400px;
      display: flex;
    }
    .item {
      flex: 1;
    }
    .item1 {
      background-color: green;
    }
    .item2 {
      background-color: darkred;
    }
  </style>
</head>
<body>
<div class="container">
  <div class="item item1"></div>
  <div class="item item2"></div>
</div>
<script src="./resizerjs-master/dist/resizer.js"></script>
<script>
  const myResizer = new Resizer('.container');
</script>
</body>
</html>

resizerjs 体量小一共才100多行,代码简洁,很容易看懂,很适合比较简单的场景。

2、splitjs

官网地址:https://github.com/nathancahill/split/tree/master/packages/splitjs

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }
    .box {
      display: flex;
    }
    #one {
      height: 400px;
      background-color: green;
    }
    #two {
      height: 400px;
      background-color: rebeccapurple;
    }
    #three {
      height: 400px;
      background-color: yellowgreen;
    }
  </style>
</head>
<body>
<div class="box">
  <div id="one">content one</div>
  <div id="two">content two</div>
  <div id="three">content three</div>
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/split.js/1.6.0/split.min.js"></script>
<script>
  Split(['#one', '#two', '#three'], {
    sizes: [25, 25, 50],
    minSize: 200,
    onDragEnd: function (sizes) {
      console.log(sizes);
    }
  });
</script>
</body>
</html>
相关推荐
薛定猫AI17 分钟前
【深度解析】从 Antigravity 更新看 Agent IDE 的工程化演进:权限、沙盒、MCP 与模型治理
前端·javascript·ide
漂流瓶jz7 小时前
总结CSS组件化演进之路:命名规范/CSS Modules/CSS in JS/原子化CSS
前端·javascript·css
steven~~~8 小时前
为什么mq报错
javascript
threelab9 小时前
Three.js 初中数学函数可视化 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
凉辰10 小时前
解决 H5 键盘遮挡与页面上推
开发语言·javascript·计算机外设
zz58812 小时前
面试官问"JS的类型"时,到底想听到什么?
javascript
gjwjuejin12 小时前
全埋点技术方案深度剖析:从事件代理到无痕采集的完整实现
javascript
前端若水13 小时前
在 Vue 2 与 Vue 3 中使用 markdown-it-vue 渲染 Markdown 和数学公式
前端·javascript·vue.js
之歆13 小时前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(下)
开发语言·前端·javascript·ecmascript
__log14 小时前
ComfyUI 集成技术方案分析报告
javascript·python·django