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数据转换
浅析上传头像示例及其注意事项
上一篇:在2003系统下建站,如何实现响应式设计适应多设备访问?
下一篇:yii高级版安装
上一篇:在2003系统下建站,如何实现响应式设计适应多设备访问?
下一篇:yii高级版安装

