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>
相关推荐
梦境之冢42 分钟前
axios 常见的content-type、responseType有哪些?
前端·javascript·http
racerun1 小时前
vue VueResource & axios
前端·javascript·vue.js
J总裁的小芒果1 小时前
THREE.js 入门(六) 纹理、uv坐标
开发语言·javascript·uv
m0_548514771 小时前
前端Pako.js 压缩解压库 与 Java 的 zlib 压缩与解压 的互通实现
java·前端·javascript
浮游本尊1 小时前
Nginx配置:如何在一个域名下运行两个网站
前端·javascript
新中地GIS开发老师1 小时前
《Vue进阶教程》(12)ref的实现详细教程
前端·javascript·vue.js·arcgis·前端框架·地理信息科学·地信
Cachel wood2 小时前
Django REST framework (DRF)中的api_view和APIView权限控制
javascript·vue.js·后端·python·ui·django·前端框架
放逐者-保持本心,方可放逐3 小时前
SSE 流式场景应用 及 方案总结
javascript·axios·fetch·eventsource
白云~️3 小时前
uniappX 移动端单行/多行文字隐藏显示省略号
开发语言·前端·javascript
小华同学ai3 小时前
vue-office:Star 4.2k,款支持多种Office文件预览的Vue组件库,一站式Office文件预览方案,真心不错
前端·javascript·vue.js·开源·github·office