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>
相关推荐
子兮曰6 小时前
OpenClaw架构揭秘:178k stars的个人AI助手如何用Gateway模式统一控制12+通讯频道
前端·javascript·github
百锦再7 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
百锦再7 小时前
React编程高级主题:测试代码
android·前端·javascript·react.js·前端框架·reactjs
颜酱8 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
小迷糊的学习记录9 小时前
Vuex 与 pinia
前端·javascript·vue.js
发现一只大呆瓜9 小时前
前端性能优化:图片懒加载的三种手写方案
前端·javascript·面试
不爱吃糖的程序媛9 小时前
Flutter 与 OpenHarmony 通信:Flutter Channel 使用指南
前端·javascript·flutter
利刃大大9 小时前
【Vue】Element-Plus快速入门 && Form && Card && Table && Tree && Dialog && Menu
前端·javascript·vue.js·element-plus
NEXT0610 小时前
AI 应用工程化实战:使用 LangChain.js 编排 DeepSeek 复杂工作流
前端·javascript·langchain
光影少年11 小时前
react的hooks防抖和节流是怎样做的
前端·javascript·react.js