JS中各种width和height的区别

本文聚焦于JS里各种width和height的分辨。作者因常混淆这些属性,遂进行详细区分。文中通过代码打印各属性实际效果,以谷歌浏览器为例,还具体阐述了client、offset、scroll相关的width和height及Top、Left属性的实际情况。

对于JS中各种width和height总是分不太清楚,今天先来仔细分辨一下,记录这些宽度和高度到底有什么秘密吧!

直接上代码:

<!DOCTYPE html>
<html>
<head>
<title></title>
<style type="text/css">
	* {
		padding: 0;
		margin: 0;
	}
	#oneDiv {
		width: 200px;
		height: 900px;
		padding: 10px;
		margin: 20px;
		border: 5px solid lightgreen;
		background: yellow;
	}
</style>
</head>
<body>
	<div id="oneDiv">我是div</div>
</body>
<script type="text/javascript">
	console.log("==============浏览器===============")
	console.log("clientWidth:", document.body.clientWidth);
	console.log("clientHeight:", document.body.clientHeight);
	console.log("clientTop:", document.body.clientTop);
	console.log("clientLeft:", document.body.clientLeft);
	console.log("offsetWidth:", document.body.offsetWidth);
	console.log("offsetHeight:", document.body.offsetHeight);
	console.log("offsetTop:", document.body.offsetTop);
	console.log("offsetLeft:", document.body.offsetLeft);
	console.log("scrollWidth:", document.body.scrollWidth);
	console.log("scrollHeight:", document.body.scrollHeight);
	console.log("scrollTop:", document.body.scrollTop);
	console.log("scrollLeft:", document.body.scrollLeft);
	console.log("==============div容器===============")
	console.log("clientWidth:", document.getElementById('oneDiv').clientWidth);
	console.log("clientHeight:", document.getElementById('oneDiv').clientHeight);
	console.log("clientTop:", document.getElementById('oneDiv').clientTop);
	console.log("clientLeft:", document.getElementById('oneDiv').clientLeft);
	console.log("offsetWidth:", document.getElementById('oneDiv').offsetWidth);
	console.log("offsetHeight:", document.getElementById('oneDiv').offsetHeight);
	console.log("offsetTop:", document.getElementById('oneDiv').offsetTop);
	console.log("offsetLeft:", document.getElementById('oneDiv').offsetLeft);
	console.log("scrollWidth:", document.getElementById('oneDiv').scrollWidth);
	console.log("scrollHeight:", document.getElementById('oneDiv').scrollHeight);
	console.log("scrollTop:", document.getElementById('oneDiv').scrollTop);
	console.log("scrollLeft:", document.getElementById('oneDiv').scrollLeft);
</script>
</html>

上文代码中,我将每种width和height都打印出来查看实际效果(由于浏览器的不同会导致clientHeight、offsetHeight和scrollHeight三个属性返回的大小有区别,我在此处仅使用谷歌浏览器做示范,在浏览器中这三者返回的都是文档的大小):
在这里插入图片描述
在这里插入图片描述
现在,我们来具体区别一下:

一、clientWidth和clientHeigh 、 clientTop和clientLeft

1,clientWidth的实际宽度

clientWidth = width+左右padding

2,clientHeigh的实际高度

clientHeigh = height + 上下padding 

3,clientTop的实际宽度

clientTop = boder.top(上边框的宽度)

4,clientLeft的实际宽度

clientLeft = boder.left(左边框的宽度)

二、offsetWidth和offsetHight 、 offsetTop和offsetLeft

1,offsetWidth的实际宽度

offsetWidth = width + 左右padding + 左右boder

2,offsetHeith的实际高度

offsetHeith = height + 上下padding + 上下boder

3,offsetTop实际宽度

offsetTop:当前元素 上边框 外边缘 到 最近的已定位父级(offsetParent) 上边框 内边缘的 距离。如果 级都没有定位,则是到body 顶部的距离。

4,offsetLeft实际宽度

offsetLeft:当前元素 左边框 外边缘 到 最近的已定位父级(offsetParent) 左边框 内边缘的距离。如果父级都没有定位,则是到body左边的距离。

三、scrollWidth和scrollHeight 、 scrollTop和scrollLeft

1,scrollWidth实际宽度

scrollWidth:获取指定标签内容层的真实宽度(可视区域宽度+被隐藏区域宽度)。

2,scrollHeight的实际高度

scrollHeight:获取指定标签内容层的真实高度(可视区域高度+被隐藏区域高度)

3,scrollTop

scrollTop :内容层顶部 到 可视区域顶部的距离。

4,scrollLeft

scrollLeft:内容层左端 到 可视区域左端的距离.

原文:https://blog.youkuaiyun.com/qq_42089654/article/details/80515916

<think>好的,用户想知道如何使用JavaScript获取WebView的宽度高度。首先,我需要回顾一下相关的知识。 根据引用内容,用户提到了在Android WebView中启用JavaScript支持,以及在页面加载完成后调用JS方法的重要性。比如引用[2]指出,JS代码必须在页面加载完成后调用,比如在onPageFinished回调中执行。此外,引用[3][5]提到了使用JavaScript获取窗口的宽度高度的具体方法,比如document.documentElement.clientWidthclientHeight。还有在鸿蒙系统中WebView的交互方式,可能涉及类似的原理。 所以,用户的问题可能是在WebView中,通过JavaScript代码获取当前视图的尺寸。需要分步骤考虑:首先在WebView设置中启用JavaScript,确保可以执行JS;然后在页面加载完成后注入JS代码,或者让页面自身的JS代码在合适的时机获取这些值。同时,可能需要通过WebView的接口将获取到的尺寸传递回原生代码,比如通过addJavascriptInterface或者loadUrl的方式。 另外,引用[5]提到在初始化时可能无法获取到DOM的尺寸,但可以通过指定高宽或延迟获取。因此,在WebView中可能需要等待页面加载完成后再执行JS代码,以确保元素已经渲染完毕,能够正确获取到尺寸。 总结下来,步骤应该是:1. 确保WebView启用JavaScript;2. 在页面加载完成后执行JS代码;3. 使用document.documentElement.clientWidthclientHeight来获取宽高;4. 可能需要将结果传回原生应用。同时需要注意不同平台(Android、HarmonyOS)的差异,但核心的JS方法应该是通用的。</think>在WebView中通过JavaScript获取宽度高度,需结合原生代码JS交互实现。具体步骤如下: --- ### 方法1:通过JS直接获取DOM尺寸 1. **启用WebView的JavaScript支持**(以Android为例): ```java WebSettings settings = webView.getSettings(); settings.setJavaScriptEnabled(true); //允许执行JS脚本[^1] ``` 2. **在页面加载完成后注入JS代码**: ```java webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { //页面加载完成后执行JS webView.loadUrl("javascript:window.JsBridge.onGetSize(" + "document.documentElement.clientWidth," + "document.documentElement.clientHeight)"); //获取可视区域尺寸[^3][^5] } }); ``` 3. **JS回调原生接口**(需提前注册JS桥接对象): ```java public class JsBridge { @JavascriptInterface public void onGetSize(int width, int height) { Log.d("WebViewSize", "Width: " + width + ", Height: " + height); } } webView.addJavascriptInterface(new JsBridge(), "JsBridge"); //注册JS桥接对象 ``` --- ### 方法2:通过Echarts初始化参数获取(适用于图表场景) 若使用Echarts等可视化库,可在初始化时直接传递尺寸参数[^5]: ```javascript //在WebView加载的页面中 const chart = echarts.init(document.getElementById('chart'), null, { width: document.documentElement.clientWidth, height: document.documentElement.clientHeight }); ``` --- ### 关键注意事项 1. **执行时机**:必须等待`onPageFinished`或DOM加载完成后再获取尺寸,否则可能得到0值[^2] 2. **鸿蒙系统实现**:通过`WebAgent`拦截URL实现类似交互逻辑[^4] 3. **动态尺寸**:监听窗口变化时需添加`resize`事件: ```javascript window.addEventListener('resize', () => { const newWidth = document.documentElement.clientWidth; const newHeight = document.documentElement.clientHeight; }); ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值