…">
当前位置:首页 > JavaScript

js实现分屏

2026-03-14 17:10:50JavaScript

分屏实现方法

使用CSS Grid布局

通过CSS Grid可以轻松实现分屏效果,结合JavaScript动态调整布局。

<div class="split-container">
  <div class="split-pane left-pane">左侧内容</div>
  <div class="split-pane right-pane">右侧内容</div>
</div>
.split-container {
  display: grid;
  grid-template-columns: 50% 50%;
  height: 100vh;
}

.split-pane {
  overflow: auto;
}
// 动态调整分屏比例
const container = document.querySelector('.split-container');
let isDragging = false;

container.addEventListener('mousedown', (e) => {
  isDragging = true;
  document.body.style.cursor = 'col-resize';
});

document.addEventListener('mousemove', (e) => {
  if (!isDragging) return;
  const containerRect = container.getBoundingClientRect();
  const percent = (e.clientX - containerRect.left) / containerRect.width * 100;
  container.style.gridTemplateColumns = `${percent}% ${100 - percent}%`;
});

document.addEventListener('mouseup', () => {
  isDragging = false;
  document.body.style.cursor = '';
});

使用Flexbox布局

Flexbox布局也是实现分屏的常用方法,适合响应式设计。

<div class="split-flex">
  <div class="split-item" id="left">左侧面板</div>
  <div class="split-divider"></div>
  <div class="split-item" id="right">右侧面板</div>
</div>
.split-flex {
  display: flex;
  height: 100vh;
}

.split-item {
  flex: 1;
  overflow: auto;
}

.split-divider {
  width: 5px;
  background: #ddd;
  cursor: col-resize;
}
const divider = document.querySelector('.split-divider');
const leftPanel = document.getElementById('left');
const rightPanel = document.getElementById('right');

divider.addEventListener('mousedown', () => {
  document.addEventListener('mousemove', resize);
  document.addEventListener('mouseup', stopResize);
});

function resize(e) {
  const containerWidth = divider.parentNode.getBoundingClientRect().width;
  const leftWidth = e.clientX / containerWidth * 100;
  leftPanel.style.flex = leftWidth;
  rightPanel.style.flex = 100 - leftWidth;
}

function stopResize() {
  document.removeEventListener('mousemove', resize);
}

使用第三方库

Split.js是一个轻量级的分屏库,使用简单:

<div id="split-container">
  <div>面板1</div>
  <div>面板2</div>
</div>
import Split from 'split.js';

Split(['#left-panel', '#right-panel'], {
  sizes: [30, 70],
  minSize: 100,
  gutterSize: 8,
});

垂直分屏实现

通过修改CSS和JavaScript可以实现垂直分屏:

.split-container-vertical {
  display: grid;
  grid-template-rows: 50% 50%;
  height: 100vh;
}

.split-divider-vertical {
  height: 5px;
  background: #ddd;
  cursor: row-resize;
}
const verticalDivider = document.querySelector('.split-divider-vertical');
verticalDivider.addEventListener('mousedown', () => {
  document.addEventListener('mousemove', verticalResize);
  document.addEventListener('mouseup', stopVerticalResize);
});

function verticalResize(e) {
  const containerHeight = divider.parentNode.getBoundingClientRect().height;
  const topHeight = e.clientY / containerHeight * 100;
  topPanel.style.flex = topHeight;
  bottomPanel.style.flex = 100 - topHeight;
}

多面板分屏

通过嵌套分屏容器可以实现复杂布局:

js实现分屏

<div class="main-container">
  <div class="horizontal-split">
    <div>顶部面板</div>
    <div class="vertical-split">
      <div>左下面板</div>
      <div>右下面板</div>
    </div>
  </div>
</div>
.main-container {
  height: 100vh;
}

.horizontal-split {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.vertical-split {
  display: flex;
  flex: 1;
}

标签: js
分享给朋友:

相关文章

js实现图片轮播

js实现图片轮播

实现基础图片轮播 使用HTML、CSS和JavaScript创建一个简单的图片轮播。HTML部分定义轮播容器和图片,CSS设置样式和动画效果,JavaScript处理轮播逻辑。 <div cl…

js 实现vue

js 实现vue

Vue.js 的基本实现 在 JavaScript 中实现 Vue.js 的核心功能,可以通过数据绑定、响应式系统和虚拟 DOM 来实现。以下是实现 Vue.js 核心功能的简化版本。 数据响应式系…

js 实现分页

js 实现分页

实现分页的基本逻辑 分页功能通常需要后端返回数据总量或总页数,前端根据当前页码和每页条数截取对应数据。以下是一个基于JavaScript的简单分页实现方案: 前端分页实现 假设已有从后端获取的完整数…

js实现图表

js实现图表

在JavaScript中实现图表通常使用流行的图表库,以下是几种常见的方法和工具: 使用Chart.js Chart.js是一个简单灵活的库,适合快速生成响应式图表。安装方式包括CDN引入或npm安…

js实现抽奖

js实现抽奖

实现抽奖功能的基本思路 抽奖功能的核心是随机选择奖项并展示结果。可以通过数组存储奖项,利用随机数生成索引,最后通过动画增强用户体验。 准备奖项数据 定义一个数组存储奖项信息,每个奖项可以包含名称、图…

js树实现

js树实现

树的基本概念 树是一种非线性的数据结构,由节点和边组成。每个节点包含一个值和指向子节点的引用。树的顶部节点称为根节点,没有子节点的节点称为叶节点。 树的实现方式 在JavaScript中,树可以通过…