位置: 编程技术 - 正文

JavaScript位置与大小(1)之正确理解和运用与尺寸大小相关的DOM属性(javascript位置属性)

编辑:rootadmin

推荐整理分享JavaScript位置与大小(1)之正确理解和运用与尺寸大小相关的DOM属性(javascript位置属性),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js定位当前位置,js编写位置,js定位到某个元素的位置,javascript按位与,js定位当前位置,javascript定位,javascript定位,javascript定位,内容如对您有帮助,希望把文章链接给更多的朋友!

在web开发中,不可避免遇到要计算元素大小以及位置的问题,解决这类问题的方法是利用DOM提供的一些API结合兼容性处理来,所有内容大概分3篇左右的文章的来说明。本文作为第一篇,介绍DOM提供的与尺寸大小相关的DOM属性,提供一些兼容性处理的方法,并结合常见的场景说明如何正确运用这些属性。

1. 正确理解offsetWidth、clientWidth、scrollWidth及相应的height属性

假设某一个元素的横纵向滚动条都拖动到最末端,则offsetWidth、clientWidth、scrollWidth等属性相应的范围如下图所示:

1)offsetWidth ,offsetHeight对应的是盒模型的宽度和高度,这两个值跟我们使用chrome审查元素时看到的尺寸一致:

2)scrollWidth,与scrollHeight对应的是滚动区域的宽度和高度 , 但是不包含滚动条的宽度!滚动区域由padding和content组成。

3)clientWidth,clientHeight对应的是盒模型除去边框后的那部分区域的宽度和高度,不包含滚动条的宽度。

4)任何一个DOM元素,都可以通过以下api快速得到offsetWidth,clientWidth,scrollWidh及相关的height属性:

//domE为一个DOM Html Element对象domE.scrollWidthdomE.scrollHeightdomE.clientWidthdomE.clientHeightdomE.offsetWidthdomE.offsetHeight//domE为一个DOM Html Element对象domE.scrollWidthdomE.scrollHeightdomE.clientWidthdomE.clientHeightdomE.offsetWidthdomE.offsetHeight

5) 这些属性在现代浏览器包括pc和mobile上几乎没有兼容性问题,可以放心使用 。如果你想了解详细的兼容性规则,可以参考下面的2篇文章:

W3C DOM Compatibility ? CSS Object Model View

cssom视图模式cssom-view-module相关整理与介绍

下面针对普通html元素,html根元素和body元素的以上相关属性一一测试,以便验证前面的结论,总结一些可在实际编码过程中直接使用的经验技巧。之所以要区分普通html元素,html根元素和body元素,是因为前面的理论,在html根元素和body元素会有一些怪异之处,需要小心处理。

注:

1、为了减少篇幅,测试贴出的代码不是完整的代码,但不影响学习参考,另外文中给出的测试结果都是在chrome(版本:.0)下运行得出的,在测试结果有差异的情况下,还会给出IE9,IE,IE,firefox(版本:.0),opera(版本:.0)的测试结果,没有差异的会在测试结果中说明,不考虑IE8及以下。

2、safari因为设备限制暂不测试,另外它跟chrome内核相同,对标准支持的可靠性差不到哪去。

3、老版本的chrome,firefox,opera也因为设备的限制无法测试,不过从浏览器对标准的支持程度考虑,这三个浏览器在很早的版本开始对W3C的标准都是比较规矩的,加之这些浏览器更新换代的速度较快,现在市面上这些浏览器主流的版本也都是较新的。

4、由于不考虑IE8及以下,同时html现在都用html5,所以document.compatMode = ‘BackCompat' 的情况不考虑。不过尽管BackCompat模式是IE6类的浏览器引出的,但是对于chrome,firefox等也存在document.compatMode = ‘BackCompat' 的情况,比如下面的这个网页,你用chrome打开,并且在console中打印document.compatMode,你会发现它的值也是BackCompat(原因跟该页面用的是html4.0的dtd有关,如果换成html4.的dtd就不会在chrome和firefox里出现该情况了):

从盒模型与js执行结果可知:

1)offsetWidth与offsetHeight与chrome审查元素看到的尺寸完全一致;

2)clientWidth与clientHeight分别等于offsetWidth与offsetHeight减掉相应边框(上下共px,左右共px)和滚动条宽度后的值(chrome下滚动条宽度为px);

3)对于scrollWidth由于没有发生横向的溢出,同时由于overflow: scroll的原因,scrollWidth 跟clientWidth相同,但是没有包含滚动条的宽度,这也验证了前面提出的结论;

4)对于scrollHeight,在这个例子中,它其实等于上下padding(共px) + div.box-2的offsetHeight(px),div.box-2:

5)以上测试还有一个css值得注意,就是box-sizing,以上代码中box-sizing设置为了content-box,如果把它改成border-box,结果也是类似的,因为offsetWidth,clientWidth还有scrollWidth对应的区域不会发生改变。

6)其它浏览器运行结果与1-5的结论一致。

测试二、验证html根元素和body元素的相关offset client scroll宽高属性:

在这个例子中,body下一共有4个box元素(总高度为 * 4 = px),body的宽是自适应的,body还有px的border,运行结果如下:

从这个结果可以看到:

1)body元素由于px边框的原因,所以clientWidth比offsetWidth少了px,这跟前面提到的理论是一致的,但是不可思议的是body的scrollWidth/scrollHeight竟然等于它的offsetWidth/offsetHeight,scrollWidth/scrollHeight是元素滚动区域的宽高度,按照前面给出的范围图来理解,body的scrollWidth/scrollHeight应该小于它的offsetWidth/offsetHeight才对;

2)docE的scrollWidth跟scrollHeight,应该等于body元素的offsetWidth跟offsetHeight,从运行结果来看,这一点是符合的,但是docE的clientWidth竟然等于它的offsetWidth,按照范围图,docE的clientWidth应该等于offsetWidth减去滚动条宽度才对。

JavaScript位置与大小(1)之正确理解和运用与尺寸大小相关的DOM属性(javascript位置属性)

其它的浏览器运行结果与chrome也有较大的差异:

IE:

1)IE下body元素没有出现chrome下body元素的问题

2)IE下html根元素也有chrome类似的问题

IE,IE9:

1)IE,9下body元素没有出现chrome下body元素的问题

2)IE,9下html根元素也没有chrome类似的问题

firefox:与IE运行结果一致。

opera: 与chrome运行结果一致,可能是因为我这个版本的opera用的跟chrome一样的webkit内核的原因。

看起来IE9就跟IE是最正常的,实在是有点难以理解,网上搜索很久,也没有找到相关资料来说明这些差异, 最后也只能采取大胆假设的方式,猜测出几个能解释这些问题的原因 :

1) 首先,网页整体的滚动,跟普通html元素的滚动不一样,普通html元素自身就是滚动对象, 但是对于网页来说,滚动对象不一定是html根元素或者body元素。因为当body内容为空时,body的高度是0,html根元素的高度也是0,如果这个时候给html或body加上overflow: scroll的css,会看到滚动条还是出现浏览器窗口的右边跟底边,所以对于网页整体的滚动,理论上,滚动对象应该是window,而不是html元素或者body元素!但实际情况并非如此,就测试的浏览器而言:

对于IE,IE9,它的滚动对象是html根元素,所以它们的html根元素的offset会包含滚动条的宽度;

对于其它浏览器,滚动对象是window,所以它们的html根元素的offset不包含滚动条的宽度。

2)第二,普通元素发生滚动时,滚动内容=它的content区域+它的padding区域,当网页整体滚动时,滚动内容应该是html根元素!但实际情况也并非如此,就测试的浏览器而言:

对于IE9,IE,IE,firefox,它们的滚动区域是html根元素,所以它们的documentElement的scrollWidth和scrollHeight始终表示网页整体的滚动区域大小!

对于chrome和opera,它们的滚动对象是body元素,所以它们的body的scrollWidth和scrollHeight始终表示网页整体的滚动区域大小!

3)第三,浏览器始终把documentElement.clientWidth和documentElement.clientHeight描述为网页可视区域除去滚动条部分的大小,跟网页内容没有关系!

以上的这些推断也并非是毫无道理,就拿滚动对象和滚动区域来说:chrome下如果要用js滚动页面到某个位置,在不使用window.scrollTo的条件下,就必须用document.body.scrollTop = xxx 来处理,而设置document.documentElement.scrollTop无效,说明chrome的整体滚动区域是由body的滚动区域决定的;而IE和火狐下如果要用js滚动页面到某个位置,在不使用window.scrollTo的条件下,就必须用document.documentElement.scrollTop = xxx来处理,设置document.body.scrollTop无效,说明IE和火狐的整体滚动区域是由html根元素的滚动区域决定的。

2. 利用JS准确获取DOM对象的大小

常见的场景有:

1)获取整个网页的可视区域的大小,不包括滚动条

2)获取整个网页的大小,包括不可见的滚动区域

3)获取一个普通html元素的大小

4)判断元素或网页有无出现滚动条

5)计算滚动条的宽度

下面针对这5个场景一一说明,以下代码均 不考虑IE8及以下,不考虑html4 ,另外请注意viewport的设置,要保证在移动设备上visual viewport与layout viewport重合。

1)如何获取整个网页的可视区域的大小,不包括滚动条

2)如何获取整个网页的大小,包括不可见的滚动区域

以上出现的window.innerWidth和window.innerHeight分别用来获取网页包括滚动条的可视区域的宽高,这也是一个兼容性不错的方法,不过从实际开发情况来看,我们需要不包括滚动条的可视区域更多一些,所以在前面没有单独介绍。另外在之前给出的PPK的博客中也有关于这两个属性的兼容性测试,可以去了解。

3)如何获取一个普通html元素的大小

简单方法:

利用getBoundingClientRect:

getBoundingClientRect将在下篇文章中跟其它与位置有关的DOM属性一起再详细介绍。

4 )判断元素或网页有无出现滚动条

当x或y方向的overflow为scroll的时候,该方向的scrollbarX为true,表示出现滚动条。

5)计算滚动条的宽度

标签: javascript位置属性

本文链接地址:https://www.jiuchutong.com/biancheng/385564.html 转载请保留说明!

上一篇:JavaScript动态设置div的样式的方法(js动态设置css样式)

下一篇:JavaScript生成二维码图片小结(js生成二维数组)

  • 所得税汇算补提所得税会计分录
  • 差额税征收标准
  • 开专用发票可以直接写加工费这个明细吗
  • 新入职员工哪月交社保
  • 固定资产投资子公司交增值税税吗
  • 软件企业两免三减半备案条件
  • 固定资产残值怎么处理什么时候处理
  • 发票入不了账怎么办
  • 发票中奖要交税吗
  • 契税和印花税的计税依据是一致吗
  • 员工垫付公司费用法规
  • 上月多计收入,本月如何调整?
  • 外出经营预缴税
  • 二手机械设备买卖合同
  • 微信提现手续费最新规定
  • 小规模纳税人出租房屋增值税税率是多少
  • 报税申报不了
  • 税务代理有哪些岗位
  • 培训过程中出现的问题及解决办法
  • 土地使用权的租赁与出租的区别
  • 金税三期得死多少企业
  • 水产类账目怎么做
  • 基金预算收入核算的内容包括
  • 固定资产达到使用状态时发生的安装费用
  • txt文档乱码怎么办
  • win10系统还原了怎么恢复
  • 无形资产一般采用直线法摊销也可采用加速法进行摊销
  • 退回的工伤费用怎么做账
  • 在win7系统中安装win10
  • PHP:mb_substr_count()的用法_mbstring函数
  • 不征税收入与免税收入的区别
  • 公积金可以支付二手房首付款吗
  • 承租人对经营租赁的会计分录
  • 专项储备怎么理解
  • add files to archive
  • mysql和php连接
  • php自定义变量的方法是
  • 魔改6.67
  • mm32开发教程
  • html获取php数据
  • 产品补发原来的要退吗
  • 通行费发票电子化 机场路
  • 企业编制现金流量表的主要目的是什么
  • 零申报失败什么原因
  • 旅游业营改增怎么报税
  • 收到发票挂账如何处理
  • 对外担保产生诉讼费用吗
  • 研发费用归集的主要范围有哪些
  • 被财政收回的财物有哪些
  • 投资收益在什么科目
  • 发票金额与实际金额不符怎么举报
  • 存货毁损损失应计入的科目是
  • 库存不够如何结算成本
  • 销售商品的折扣
  • 其他综合收益是当期损益吗
  • 什么情况下增值税发票不能抵扣
  • 金税盘维护费抵减分录
  • 收到专票可以不签字吗
  • 固定资产建账为什么不能直接输入名字
  • 安装2个win10系统
  • win10自带的音乐播放器groove如何设置
  • windows2003服务
  • 老毛桃u盘启动盘制作工具怎么安装win10系统 老毛桃u盘安装win10系统图文教程
  • win10系统浏览器设置主页
  • 索尼笔记本安装软件顺序
  • android:Background线程池和UiThread线程池
  • shell linux命令详解
  • div css table
  • node.js中的http.response.getHeader方法使用说明
  • ubuntu不待机
  • 用shell脚本实现菜单页面
  • shell脚本if用法
  • Node.js中 __dirname 的使用介绍
  • 游戏客服怎么跟客户聊天
  • jquery defaultvalue
  • Windows环境下搭建Python开发环境的方法
  • bootstrapping怎么做
  • 2023河南新农合截止日期新规
  • 中华人民共和国刑法
  • 杭州没有户口可以上幼儿园吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设