hook实现元素放大浏览

前言

之前看到一个效果元素的放大浏览,看起来挺有意思的。现在也来试着用hook来实现一个这样的效果。后面有代码地址。

还是先来看看效果

正文

实现元素放大浏览的原理也很简单,使用fixed定位再配合translate来移动、缩放。

过程中要处理的几个问题:

  1. 确定移动的距离和缩放大小
  2. 怎么放大浏览时,页面中其他元素位置不受影响
  3. 在页面大小发生变化时,怎么处理

确定移动距离和缩放大小

元素中心点到屏幕中心点移动距离可以根据以下的公式算出,lefttop为元素在页面中的位置。

js 复制代码
let transformX = screenWidth / 2 - (left + width / 2)
let transformY = screenHeight / 2 - (top + height / 2)

对于放大比例的确定,我们只要计算放大浏览元素宽高和屏幕大小的比例,选择小的那个就可以了(选择大的会使屏幕装不下元素)

放大浏览时,页面中其他元素位置不受影响

这个的原理也简单,我们只要在元素放大浏览时在同一个位置创建一个一模一样的元素放在原来位置就可以了。

复制放大浏览元素样式,并隐藏元素

放大浏览时插入占位元素,否则移除占位元素

页面大小发生变化

在页面大小发生变化时,只需要重新计算移动距离和放大比例就可以了

结语

仓库地址

感兴趣的可以去试试

相关推荐
Alair‎4 分钟前
前端开发之环境配置
前端·react.js
Deca~9 分钟前
VueVirtualLazyTree-支持懒加载的虚拟树
前端·javascript·vue.js
爱上妖精的尾巴17 分钟前
7-11 WPS JS宏 对象的属性值为函数的写法与用法
前端·javascript·wps·js宏·jsa
zuozewei18 分钟前
零基础 | 使用LangChain框架实现ReAct Agent
前端·react.js·langchain
坠入暮云间x18 分钟前
React Native for OpenHarmony开发环境搭建指南(一)
前端·react native·开源
爱上妖精的尾巴21 分钟前
7-12 WPS JS宏 this、return用构造函数自定义类-1:对象内部函数,外部调用的写法
前端·javascript·wps·js宏·jsa
白鳯21 分钟前
分形世界:React实现交互式分形图绘制与导出
react.js·前端框架·cursor·分形·vibe coding·分形绘制·数学之美
har01d27 分钟前
AI生成的 vue3 日历组件,显示农历与节日,日期可选择,年月可切换
前端·vue.js·节日
冲刺逆向33 分钟前
【js逆向案例六】创宇盾(加速乐)通杀模版
java·前端·javascript
我穿棉裤了35 分钟前
文字换行自动添加换行符“-”
前端·javascript·vue.js