hook实现元素放大浏览

前言

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

还是先来看看效果

正文

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

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

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

确定移动距离和缩放大小

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

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

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

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

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

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

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

页面大小发生变化

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

结语

仓库地址

感兴趣的可以去试试

相关推荐
EndingCoder17 小时前
枚举类型:常量集合的优雅管理
前端·javascript·typescript
Electrolux17 小时前
[wllama]纯前端实现大语言模型调用:在浏览器里跑 AI 是什么体验。以调用腾讯 HY-MT1.5 混元翻译模型为例
前端·aigc·ai编程
sanra12317 小时前
前端定位相关技巧
前端·vue
起名时在学Aiifox17 小时前
从零实现前端数据格式化工具:以船员经验数据展示为例
前端·vue.js·typescript·es6
oMcLin17 小时前
如何在Manjaro Linux上配置并优化Caddy Web服务器,确保高并发流量下的稳定性与安全性?
linux·服务器·前端
码途潇潇18 小时前
JavaScript 中 ==、===、Object.is 以及 null、undefined、undeclared 的区别
前端·javascript
之恒君18 小时前
Node.js 模块加载 - 4 - CJS 和 ESM 互操作避坑清单
前端·node.js
be or not to be18 小时前
CSS 背景(background)系列属性
前端·css·css3
前端snow18 小时前
在手机端做个滚动效果
前端
webkubor18 小时前
🧠 2025:AI 写代码越来越强,但我的项目返工却更多了
前端·机器学习·ai编程