js实现卷轴,中间可滑动方块,左右两侧对比

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Div Swipe 示例</title>
    <style>
      * {
        box-sizing: border-box;
      }

      html,
      body {
        padding: 0;
        margin: 0;
        height: 100%;
        font-family: "Segoe UI", "PingFang SC", sans-serif;
        background: #f6f8fb;
      }

      .wrapper {
        position: relative;
        width: min(95vw, 1200px);
        height: min(80vh, 700px);
        margin: 30px auto 20px;
        border-radius: 12px;
        overflow: hidden;
        box-shadow: 0 8px 25px rgba(15, 23, 42, 0.18);
      }

      .panel {
        position: absolute;
        inset: 0;
        display: grid;
        place-items: center;
        color: #fff;
        font-size: 32px;
        font-weight: 600;
        text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
      }

      .panel.panel-left {
        background: linear-gradient(135deg, #43cea2 0%, #185a9d 100%);
      }

      .panel.panel-right {
        background: linear-gradient(135deg, #ff512f 0%, #dd2476 100%);
        clip-path: inset(0 0 0 50%);
      }

      .panel iframe {
        width: 100%;
        height: 100%;
        border: none;
      }

      .handle {
        position: absolute;
        top: 0;
        bottom: 0;
        width: 4px;
        background: #fff;
        border-radius: 4px;
        box-shadow: 0 0 8px rgba(0, 0, 0, 0.4);
        cursor: ew-resize;
        transform: translateX(-50%);
      }

      .handle::before {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        width: 36px;
        height: 36px;
        border-radius: 50%;
        border: 3px solid #fff;
        background: rgba(24, 90, 157, 0.95);
        transform: translate(-50%, -50%);
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.35);
      }

      .tip {
        text-align: center;
        color: #4b4d52;
        font-size: 14px;
      }
    </style>
  </head>
  <body>
    <div class="wrapper" id="swipeWrapper">
      <div class="panel panel-left"></div>
      <div class="panel panel-right" id="panelRight">After</div>
      <div class="handle" id="handle"></div>
    </div>
    <p class="tip">在两个 div 上实现的 Swipe,对比任意内容或样式</p>

    <script>
      const wrapper = document.getElementById("swipeWrapper");
      const handle = document.getElementById("handle");
      const panelRight = document.getElementById("panelRight");

      let isDragging = false;

      const setPosition = (clientX) => {
        const rect = wrapper.getBoundingClientRect();
        const clamped = Math.min(Math.max(clientX - rect.left, 0), rect.width);
        const percent = (clamped / rect.width) * 100;
        panelRight.style.clipPath = `inset(0 ${100 - percent}% 0 0)`;
        handle.style.left = `${percent}%`;
      };

      const onPointerMove = (event) => {
        if (!isDragging) return;
        setPosition(event.clientX ?? event.touches?.[0]?.clientX ?? 0);
      };

      const startDrag = (event) => {
        isDragging = true;
        wrapper.setPointerCapture?.(event.pointerId);
        setPosition(event.clientX ?? event.touches?.[0]?.clientX ?? 0);
      };

      const stopDrag = (event) => {
        isDragging = false;
        wrapper.releasePointerCapture?.(event.pointerId);
      };

      handle.addEventListener("pointerdown", startDrag);
      window.addEventListener("pointermove", onPointerMove);
      window.addEventListener("pointerup", stopDrag);

      // 初始化到中间位置
      setPosition(wrapper.getBoundingClientRect().width / 2);
    </script>
  </body>
</html>
相关推荐
摇滚侠19 分钟前
外边距问题 塌陷问题 HTML CSS
css
前端摸鱼匠30 分钟前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker1 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
W.A委员会1 小时前
CSS中的单位
css·css3·html5
nbwenren2 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Linsk3 小时前
Java和JavaScript的关系真是雷峰和雷峰塔的关系吗?
java·javascript·oracle
当时只道寻常3 小时前
浏览器文本复制到剪贴板:企业级最佳实践
javascript
Alice-YUE4 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀5 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
莎士比亚的文学花园5 小时前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript