如何实现类Mac Dock的弹性缩放动画

效果概述

实现了以下特性:

  • 鼠标悬停时展开图标
  • 光标移动时图标弹性缩放
  • 相邻图标间距自动适应
  • 平滑过渡动画

注:如果你想先看效果或完整代码可以去codesandbox codesandbox.io/p/sandbox/b...

使用了我自己写的框架 belling js(在npm上找belling就可以了),是一个高性能的极简mvvm框架。如果你是用vue或react,把state转换成createSignal, h函数转换成jsx就可以了。

核心实现原理

1. 布局架构

使用绝对定位的弹性容器:

javascript 复制代码
ForIn("div", apps, (i, v) => {
  // 生成每个dock图标
}).style({
  position: "relative",
  width: () => apps.v.length * (w + gap) + gap + 'px',
  height: w + 'px'
})

2. 动态响应体系

基于响应式状态管理:

javascript 复制代码
const x = state(0); // 鼠标X坐标
const hover = state(false); // 悬停状态

3. 鼠标交互

通过事件监听更新状态:

javascript 复制代码
.on({
  mouseenter() { hover.v = true },
  mouseleave() { hover.v = false },
  mousemove(e) {
    x.v = e.clientX - ele.dom.offsetLeft;
  }
})

灵魂所在:缩放函数解析

核心算法

javascript 复制代码
function scale(x) {
  return x > 0 ?
    scaleRatio * Math.log(x + 1) + x :
    -(scaleRatio * Math.log(-x + 1) - x);
}

实现原理

这个函数实现了非对称弹性缩放效果:

scaleRatio: 缩放强度系数(示例值为2)

函数特点:

分界处理:偶函数沿鼠标两侧对称 对数基底:使用log2实现初始变化率大,即鼠标位置放大 叠加:位移 + 对数缩放分量

  • 中心点附近变化剧烈
  • 边缘区域变化平缓

动态尺寸计算

结合缩放函数实现弹性布局:

javascript

Copy

scss 复制代码
function size() {
  const l = i.v * (w + gap); // 原始左坐标
  const r = l + w;           // 原始右坐标
  
  // 计算缩放后的实际宽度
  return scale(r - x.v) - scale(l - x.v) + "px";
}

效果优化

添加一点CSS过渡动画:

css 复制代码
transition: all 0.1s

扩展建议

调节scaleRatio控制缩放幅度 修改对数基底改变衰减曲线 实现图标内容缩放

相关推荐
汉得数字平台9 分钟前
汉得H-AI飞码——前端编码助手V1.1.2正式发布:融业务知识,提开发效能
前端·人工智能·智能编码
前端小万9 分钟前
Jenkins 打包崩了?罪魁是 package.json 里的 ^
前端·jenkins
编程小白gogogo9 分钟前
苍穹外卖前端环境搭建
前端
光影少年13 分钟前
web端安全问题有哪些?
前端·安全
行走的陀螺仪20 分钟前
Vite & Webpack 插件/Loader 封装完全指南
前端·webpack·node.js·vite·前端工程化·打包构建
1024肥宅25 分钟前
浏览器网络请求 API:全面解析与高级封装(1)
前端·websocket·axios
小费的部落27 分钟前
Excel 在Sheet3中 匹配Sheet1的A列和Sheet2的A列并处理空内容
java·前端·excel
霍格沃兹测试学院-小舟畅学28 分钟前
Cypress 入门与优势分析:前端自动化测试的新利器
前端
1024肥宅28 分钟前
浏览器网络请求 API:全面解析与高级封装(2)
前端·websocket·axios
幼儿园技术家34 分钟前
深入理解 CSR / SSR / SSG:前端三种渲染模式的本质与选型
前端