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>
相关推荐
2501_920931701 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05282 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔2 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李2 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN2 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒2 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库2 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
方也_arkling2 小时前
Element Plus主题色定制
javascript·sass
2601_949809592 小时前
flutter_for_openharmony家庭相册app实战+我的Tab实现
java·javascript·flutter
Up九五小庞2 小时前
开源埋点分析平台 ClkLog 本地部署 + Web JS 埋点测试实战--九五小庞
前端·javascript·开源