js获取height和width总结

JS获取页面尺寸总结
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
<html>  
<head>  
    <title>js获取height和width总结</title>  
    <meta content="text/html;charset=UTF-8" http-equiv="Content-Type"/>  
    <script type="text/javascript" src="js/jquery-1.5.2.js"></script>  
    <script type="text/javascript" >  
       $(document).ready(function()  
        {  
        alert("浏览器当前窗口可视区域高度:"+$(window).height()); //浏览器当前窗口可视区域高度  
        alert("浏览器当前窗口文档的高度:"+$(document).height()); //浏览器当前窗口文档的高度  
        alert("浏览器当前窗口文档body的高度:"+$(document.body).height());//浏览器当前窗口文档body的高度  
        alert("浏览器当前窗口文档body的总高度 包括border padding margin:"+$(document.body).outerHeight(true));//浏览器当前窗口文档body的总高度 包括border padding margin  
        alert("浏览器当前窗口可视区域宽度:"+($(window).width())); //浏览器当前窗口可视区域宽度  
        alert("浏览器当前窗口文档对象宽度:"+$(document).width());//浏览器当前窗口文档对象宽度  
        alert("浏览器当前窗口文档body的高度:"+$(document.body).width());//浏览器当前窗口文档body的高度  
        alert("浏览器当前窗口文档body的总宽度 包括border padding margin:"+$(document.body).outerWidth(true));//浏览器当前窗口文档body的总宽度 包括border padding margin  
        alert("显示器分辨率,只能用JavaScript代码获取高度:"+screen.height);//显示器分辨率,只能用JavaScript代码获取  
        alert("显示器分辨率,只能用JavaScript代码获取宽度:"+screen.width);  
        })  ;  
  
  
    </script>  
  
</head>  
<body>  
    <ul>  
         <li>  网页可见区域宽: document.body.clientWidth    </li>  
         <li>   网页可见区域高: document.body.clientHeight  </li>  
         <li>   网页可见区域宽: document.body.offsetWidth (包括边线的宽)</li>  
         <li>  网页可见区域高: document.body.offsetHeight (包括边线的高)    </li>  
         <li>  网页正文全文宽: document.body.scrollWidth                   </li>  
         <li>   网页正文全文高: document.body.scrollHeight                       </li>  
         <li>    网页被卷去的高: document.body.scrollTop  </li>  
         <li>    网页被卷去的左: document.body.scrollLeft  </li>  
         <li>    网页正文部分上: window.screenTop   </li>  
         <li>    网页正文部分左: window.screenLeft   </li>  
         <li>   屏幕分辨率的高: window.screen.height</li>  
         <li>   屏幕分辨率的宽: window.screen.width  </li>  
         <li>   屏幕可用工作区高度: window.screen.availHeight</li>  
         <li>   屏幕可用工作区宽度: window.screen.availWidth </li>  
     </ul>  
  
</body>  
</html>  

 

<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; }); ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值