0

0

JS中得获取宽度的方法实例

零下一度

零下一度

发布时间:2017-05-06 15:26:11

|

2138人浏览过

|

来源于php中文网

原创


window与document的这些属性的值会不太兼容,会在后面补充说。
一下效果展示忽略ie9之前浏览器,主要考虑主流浏览器与手机端的效果。

  • 可以获得宽度与高度的属性

    • clientHeight 与clientWidth 指元素的客户区大小,即 可见内容区+padding

         #t1{
             width: 100px;
             height: 100px;
             border: 4px solid yellowgreen;
             background: yellow;
             padding: 10px;
         }

      p.clientWidth+';'+p.clientHeight;

      p.clientWidth+';'+p.clientHeight;

      120=width(100)+padding(10)*2;
      不加边框,当内容溢出或者出现滚动条时的宽度与高度都不会算在内。
      是dom对象的可见宽度,这里的可见是针对设置overflow: scroll;后部分内容隐藏而说的。

    • offsetHeight与offsetWidth 是元素的外在大小,即 border +padding+可见内容区

      p.offsetWidth+';'+p.offsetHeight

      p.offsetWidth+';'+p.offsetHeight

      128 = width(100)+padding(10)2+border(4)2
      上图内容区溢出隐藏,是因为设置了overflow: scroll;才会有这样的现象。

    • scrolWidth与scrollHeight是元素的实际大小,即 实际内容区+padding

      p.scrollWidth+';'+p.scrollHeight

      p.scrollWidth+';'+p.scrollHeight

以上这三对属性都是针对dom元素的,可以测得元素的宽度,但是,细心的会发现,以上三种并没有提供获得width(100)的方法,所以可以使用window.getComputedStyle(p,null).getPropertyValue('width');
这样获得就是100。


其实比较难理解的是像window、document.body、document. documentElement这两个dom对象在获得他们的宽度时会有各种问题。
现在开始撕一下这其中的神奇。。。

  • document.body与document. documentElement
    前者是body,后者是html。但是现在大家都习惯将元素默认的padding与margin设置为0,这样无论是通过以上两种谁去访问clientWidth都是一样的值(电脑端一致)。
    但是手机端访问这两个值的时候会随着由于是客户端,我们会对网页的meta标签做一些设置,然后通过这两个对象访问的属性的值就不一样。但是由于body是html的子标签,所以获得可视窗口(clientWidth)的大小,建议使用后者document. documentElement.clientWidth。

    英特尔AI工具
    英特尔AI工具

    英特尔AI与机器学习解决方案

    下载
    document对象有个属性compatMode ,它有两个值:BackCompat     对应quirks modeCSS1Compat     对应strict modeIE6以前的浏览器就是第一种渲染模式,导致IE6要是想获得可视窗口(clientWidth)时,必须使用document.body.clientWidth这个来访问。IE6我实习的公司已经放弃啦。
综上:抛弃document.body的用法,使用document. documentElement。
  • window.innerWidth与document. documentElement.clientWidth用哪个?
    接下来说的是不为网页添加meta标签的效果,添加标签的我觉得应该另外写一篇,因为会涉及到自适应的知识。
    我做了再安卓机浏览器,iPhone的safari浏览器以及这两种手机内微信内访问网页运行的qq浏览器的测试。
    测试结果肯定是不统一的。
    测试前提:不为页面设置固定的宽度,不设置meta标签。
    测试结果:

属性 安卓机 iphone
window.innerWidth 980px 980px
~.~.clientWidth 980px 980px
属性 安卓机微信 iphone微信
window.innerWidth 320px 980px
~.~.clientWidth 980px 980px

总是会有捣蛋鬼。。。
综上:如果想要获得手机端页面的可视宽度,建议使用
document. documentElement.clientWidth

在下一篇,笔记中,会对这个属性在meta标签的不同设置下的值进行分析。

BTW:我又回来,好好学习啦!

【相关推荐】

1. 免费js在线视频教程

2. JavaScript中文参考手册

3. php.cn独孤九贱(3)-JavaScript视频教程

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

12

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

4

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

18

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

19

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

3

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.6万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号