js 获取图像缩放后的实际宽高,位置等信息

发布时间 - 2026-01-11 00:02:35    点击率:

项目中遇到图片实际显示尺寸的判定问题,图片可能被缩放过,所以实际显示的宽高无法通过常见的各种width,height拿到(都是得到图像的自然宽度或者字面宽度,并非实际显示结果)

在网上百度了一大圈也没有找到,今天早上偶然找到2个很方便的方法:

object.getClientRects();object.getBoundingClientRect();

可以轻易获得当前元素的绝对位置(不含scrollLeft和scrollTop,需要用的话单独加上去)和显示出来的实际宽高

getClientRects 和 getBoundingClientRect 的区别

getClientRects 返回一个TextRectangle集合,就是TextRectangleList对象。

getBoundingClientRect 返回 一个TextRectangle对象,即使DOM里没有文本也能返回TextRectangle对象.

浏览器差异:

除了safari,firefox2.0外所有浏览器都支持getClientRects和getBoundingClientRect,

firefox 3.1给TextRectangle增加了 width 和 height。

ie 和非ie浏览器在使用getClientRects还是有些差别的,ie获取TextRectangleList的范围很大。而非ie获取的范围比较小, 只有display:inline的对象才能获取到TextRectangleList,例如em i span 等标签。

通过测试,至少Chrome 2+\Safari 4\Firefox3.5\0pera 9.63+已经支持getBoundingClientRect方法。

出于浏览器兼容的考虑,现在用得最多的是getBoundingClientRect,经常用来获取一个element元素的viewport坐标。

MDN关于getBoundingClientRect的详细介绍:https://developer.mozilla.org/zh-CN/docs/Web/API/Element/getBoundingClientRect

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# 图像缩放  # PHP实现对png图像进行缩放的方法(支持透明背景)  # C#数字图像处理之图像缩放的方法  # Android 图像处理(类型转换  # 比例缩放  # 倒影  # 圆角)的小例子  # Android开发之图形图像与动画(二)Animation实现图像的渐变/缩放/位移/旋转  # 都是  # 也能  # 详细介绍  # 不含  # 较小  # 而非  # 没有找到  # 很方便  # 用得  # 需要用  # 最多的是  # 增加了  # 大圈  # 早上  # 在网上  # ff  # width  # height  # TextRectangle  # TextRectangleList 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 黑客入侵网站服务器的常见手法有哪些?  如何用搬瓦工VPS快速搭建个人网站?  Laravel如何为API生成Swagger或OpenAPI文档  Laravel distinct去重查询_Laravel Eloquent去重方法  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  零服务器AI建站解决方案:快速部署与云端平台低成本实践  如何快速使用云服务器搭建个人网站?  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  如何在VPS电脑上快速搭建网站?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  高端建站三要素:定制模板、企业官网与响应式设计优化  Laravel的.env文件有什么用_Laravel环境变量配置与管理详解  香港服务器租用每月最低只需15元?  php打包exe后无法访问网络共享_共享权限设置方法【教程】  Laravel如何配置Horizon来管理队列?(安装和使用)  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  详解Oracle修改字段类型方法总结  青岛网站建设如何选择本地服务器?  简单实现jsp分页  如何用虚拟主机快速搭建网站?详细步骤解析  Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】  网站制作企业,网站的banner和导航栏是指什么?  网站制作软件有哪些,制图软件有哪些?  Laravel如何处理和验证JSON类型的数据库字段  jquery插件bootstrapValidator表单验证详解  详解Android——蓝牙技术 带你实现终端间数据传输  手机软键盘弹出时影响布局的解决方法  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  如何在橙子建站中快速调整背景颜色?  Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  详解MySQL数据库的安装与密码配置  如何快速搭建高效简练网站?  高防服务器如何保障网站安全无虞?  网站图片在线制作软件,怎么在图片上做链接?  php结合redis实现高并发下的抢购、秒杀功能的实例  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  利用python获取某年中每个月的第一天和最后一天  Mybatis 中的insertOrUpdate操作  Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势  如何用西部建站助手快速创建专业网站?  百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏  Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出  Laravel Eloquent模型如何创建_Laravel ORM基础之Model创建与使用教程  千库网官网入口推荐 千库网设计创意平台入口  ,南京靠谱的征婚网站?  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  公司门户网站制作流程,华为官网怎么做?  高防服务器租用首荐平台,企业级优惠套餐快速部署  Laravel API资源类怎么用_Laravel API Resource数据转换  浅析上传头像示例及其注意事项