前端区域块拖拽的纯css纯js、splitpanes插件的方法

要实现一个前端区块的拖拽功能,你可以使用纯CSS3或纯JavaScript,也可以使用splitpanes插件。以下是每种方法的简要说明和示例代码:

  1. 纯CSS3方法:

CSS3可以通过resize属性和grid布局实现拖拽功能。但这种方法不具备复杂的交互,适合简单的拖拽操作。




.container {
  display: grid;
  grid-template-columns: 1fr 3px 1fr;
}
 
.resizable {
  overflow: hidden;
  resize: horizontal;
  border: 1px solid #000;
  padding: 10px;
}
 
.resizable:hover {
  cursor: e-resize;
}



<div class="container">
  <div class="resizable">区块1</div>
  <div class="resizable">区块2</div>
</div>
  1. 纯JavaScript方法:

使用JavaScript可以实现更复杂的拖拽功能。




<div class="container">
  <div class="block" id="block1">区块1</div>
  <div class="block" id="block2">区块2</div>
</div>



const container = document.querySelector('.container');
let dragging = null;
 
container.addEventListener('mousedown', (e) => {
  if (e.target.classList.contains('block')) {
    dragging = e.target;
    document.body.style.cursor = 'ew-resize';
  }
});
 
document.addEventListener('mousemove', (e) => {
  if (dragging) {
    const x = e.clientX - container.offsetLeft;
    dragging.style.width = `${x}px`;
  }
});
 
document.addEventListener('mouseup', (e) => {
  dragging = null;
  document.body.style.cursor = '';
});
  1. 使用splitpanes插件:

Splitpanes是一个流行的JavaScript库,可以轻松地创建可拖拽分割的区块。

首先,你需要在HTML中引入splitpanes库:




<link rel="stylesheet" href="https://unpkg.com/splitpanes@latest/dist/splitpanes.css">
<script src="https://unpkg.com/splitpanes@latest/dist/splitpanes.js"></script>

然后,你可以这样使用它:




<div class="splitpanes">
  <div class="splitpanes__panel">区块1</div>
  <div class="splitpanes__panel">区块2</div>
</div>



Splitpanes.init({
  element: document.querySelector('.splitpanes')
});

以上三种方法都可以实现前端区块拖拽的功能,具体使用哪一种取决于你的项目需求和个人喜好。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日