`
wfdoublext
  • 浏览: 128664 次
  • 性别: Icon_minigender_1
  • 来自: 青岛
社区版块
存档分类
最新评论

窗体大小

阅读更多
网页可见区域宽:document.body.clientWidth
网页可见区域高:document.body.clientHeight
网页可见区域宽:document.body.offsetWidth (包括边线的宽)
网页可见区域高:document.body.offsetHeight (包括边线的宽)
网页正文全文宽:document.body.scrollWidth
网页正文全文高:document.body.scrollHeight
网页被卷去的高:document.body.scrollTop
网页被卷去的左:document.body.scrollLeft
网页正文部分上:window.screenTop
网页正文部分左:window.screenLeft
屏幕分辨率的高:window.screen.height
屏幕分辨率的宽:window.screen.width
屏幕可用工作区高度:window.screen.availHeight
屏幕可用工作区宽度:window.screen.availWidth

HTML精确定位:scrollLeft,scrollWidth,clientWidth,offsetWidth
scrollHeight: 获取对象的滚动高度。
scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离
scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最顶端之间的距离
scrollWidth:获取对象的滚动宽度
offsetHeight:获取对象相对于版面或由父坐标 offsetParent 属性指定的父坐标的高度
offsetLeft:获取对象相对于版面或由 offsetParent 属性指定的父坐标的计算左侧位置
offsetTop:获取对象相对于版面或由 offsetTop 属性指定的父坐标的计算顶端位置
event.clientX 相对文档的水平座标
event.clientY 相对文档的垂直座标
event.offsetX 相对容器的水平坐标
event.offsetY 相对容器的垂直坐标
document.documentElement.scrollTop 垂直方向滚动的值
event.clientX+document.documentElement.scrollTop 相对文档的水平座标+垂直方向滚动的量


IE,FireFox 差异如下:

IE6.0、FF1.06+:

clientWidth = width + padding

clientHeight = height + padding

offsetWidth = width + padding + border

offsetHeight = height + padding + border

IE5.0/5.5:
clientWidth = width - border

clientHeight = height - border

offsetWidth = width

offsetHeight = height

(需要提一下:CSS中的margin属性,与clientWidth、offsetWidth、clientHeight、offsetHeight均无关)

网页可见区域宽: document.body.clientWidth
网页可见区域高: document.body.clientHeight
网页可见区域宽: document.body.offsetWidth (包括边线的宽)
网页可见区域高: document.body.offsetHeight (包括边线的高)
网页正文全文宽: document.body.scrollWidth
网页正文全文高: document.body.scrollHeight
网页被卷去的高: document.body.scrollTop
网页被卷去的左: document.body.scrollLeft
网页正文部分上: window.screenTop
网页正文部分左: window.screenLeft
屏幕分辨率的高: window.screen.height
屏幕分辨率的宽: window.screen.width
屏幕可用工作区高度: window.screen.availHeight
屏幕可用工作区宽度: window.screen.availWidth

-------------------

技术要点
本节代码主要使用了Document对象关于窗口的一些属性,这些属性的主要功能和用法如下。

要得到窗口的尺寸,对于不同的浏览器,需要使用不同的属性和方法:若要检测窗口的真实尺寸,在Netscape下需要使用Window的属性;在 IE下需要深入Document内部对body进行检测;在DOM环境下,若要得到窗口的尺寸,需要注意根元素的尺寸,而不是元素。

Window对象的innerWidth属性包含当前窗口的内部宽度。Window对象的innerHeight属性包含当前窗口的内部高度。

Document对象的body属性对应HTML文档的标签。Document对象的documentElement属性则表示HTML文档的根节点。

document.body.clientHeight表示HTML文档所在窗口的当前高度。document.body. clientWidth表示HTML文档所在窗口的当前宽度。

实现代码

1
                        2
                        3
                        4
                        5
                        6
                        7
                        8
                        9
                        10
                        11
                        12
                        13
                        14
                        15
                        16
                        17
                        18
                        19
                        20
                        21
                        22
                        23
                        24
                        25
                        26
                        27
                        28
                        29
                        30
                        31
                        32
                        33
                        34
                        35
                        36
                        37
                        38
                        39
                        40
                        41
                        42
                        43
                        44
                        45
                        46
                        47
                        48
 < !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
                        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
                        <html xmlns="http://www.w3.org/1999/xhtml">
                        <head>
                        <title>请调整浏览器窗口</title>
                        <meta http-equiv="content-type" content="text/html; charset=gb2312">
                        </meta></head>
                        <body>
                        <h2 align="center">请调整浏览器窗口大小</h2><hr />
                        <form action="#" method="get" name="form1" id="form1">
                        <!--显示浏览器窗口的实际尺寸-->
                        浏览器窗口 的 实际高度: <input type="text" name="availHeight" size="4"/><br />
                        浏览器窗口 的 实际宽度: <input type="text" name="availWidth" size="4"/><br />
                        </form>
                        <script type="text/javascript">
                        <!-- 
                        var winWidth = 0;
                        var winHeight = 0;
                        function findDimensions() //函数:获取尺寸
                        {
                        //获取窗口宽度
                        if (window.innerWidth)
                        winWidth = window.innerWidth;
                        else if ((document.body) && (document.body.clientWidth))
                        winWidth = document.body.clientWidth;
                        //获取窗口高度
                        if (window.innerHeight)
                        winHeight = window.innerHeight;
                        else if ((document.body) && (document.body.clientHeight))
                        winHeight = document.body.clientHeight;
                        //通过深入Document内部对body进行检测,获取窗口大小
                        if (document.documentElement  && document.documentElement.clientHeight && document.documentElement.clientWidth)
                        {
                        winHeight = document.documentElement.clientHeight;
                        winWidth = document.documentElement.clientWidth;
                        }
                        //结果输出至两个文本框
                        document.form1.availHeight.value= winHeight;
                        document.form1.availWidth.value= winWidth;
                        }
                        findDimensions();
                        //调用函数,获取数值
                        window.onresize=findDimensions;
                        
                        //-->
                        </script>
                        </body>
                        </html>
 

源程序解读

(1)程序首先建立一个表单,包含两个文本框,用于显示窗口当前的宽度和高度,并且,其数值会随窗口大小的改变而变化。

(2)在随后的JavaScript代码中,首先定义了两个变量winWidth和winHeight,用于保存窗口的高度值和宽度值。

(3)然后,在函数findDimensions ( )中,使用window.innerHeight和window.innerWidth得到窗口的高度和宽度,并将二者保存在前述两个变量中。

(4)再通过深入Document内部对body进行检测,获取窗口大小,并存储在前述两个变量中。

(5)在函数的最后,通过按名称访问表单元素,结果输出至两个文本框。

(6)在JavaScript代码的最后,通过调用findDimensions ( )函数,完成整个操作。

 

  • 大小: 11.4 KB
分享到:
评论

相关推荐

    VB实现窗口文字大小随窗体大小变化.rar

    VB实现窗口文字大小随窗体大小变化,实现了窗体文字的随窗口大小自适应改变,只要用鼠标拖动窗口的大小,即可改变窗口内所属控件的文字大校自适应大小的窗口框架,注意,把需要随窗体改变大小的空间的tab属性设置成 ...

    窗体控件大小随窗体大小变化而变化

    `Button1.Width`和`Button1.Height`被设置为相对窗口大小的比例,`Button1.Top`和`Button1.Left`确保按钮始终居中显示。 当然,对于复杂的界面,可能有多个控件需要调整。在这种情况下,可以使用循环或者结构化的...

    C#无标题栏拖动及调整窗口大小

    - 在处理窗口大小调整时,要确保不会出现负数的宽度或高度,以及避免窗口变得太小以至于无法显示内容。 以上就是实现C#无标题栏拖动和调整窗口大小的基本步骤。通过这个过程,你可以创建出具有高度定制性的用户...

    vb.net控件随窗口大小调整

    在VB.NET开发中,有时我们需要让窗体上的控件随着窗体大小的变化而自动调整位置与尺寸,以适应不同的屏幕分辨率或用户自定义的窗口大小。本文将详细介绍如何实现这一功能,并通过示例代码进行解释。 #### 原理说明 ...

    QT 隐藏标题栏后改变窗体大小

    这需要我们监控`QCursor::pos()`来确定鼠标相对于窗体的位置,同时在`mouseMoveEvent()`中根据鼠标位置和状态来调整窗口大小。 5. **事件过滤器(QObject::installEventFilter)**:为了监听所有相关的鼠标事件,...

    winform无边框在panel上拖动窗口位置,改变窗口大小

    标题“winform无边框在panel上拖动窗口位置,改变窗口大小”正是涉及到这个主题。下面将详细解释如何实现这一功能,以及涉及的相关知识点。 首先,我们需要了解`C# WinForm`的基础知识。`C# WinForm`是.NET ...

    C# 窗体中的控件及菜单随窗体大小而变化

    C# 窗体中的控件及菜单随窗体大小而变化 让C#窗体中的控件、按钮以及菜单等随窗体的大小变化而变化,在Word中,大家会见到,当Word的窗体不是最大化的时候,那些操作按钮会自动隐藏起来,用箭头来代替,点击箭头会...

    vb6.0控件适应窗体大小

    在VB6.0编程环境中,开发用户界面时,我们经常需要设计窗体(Form)以适应不同的屏幕分辨率和用户窗口大小调整。标题“vb6.0控件适应窗体大小”涉及的核心技术是如何使窗体上的控件随着窗体尺寸的变化而自动调整布局...

    c# 控件大小(及字体)随窗口大小改变自动缩放

    本篇文章将深入探讨如何实现C#控件大小及字体随窗口大小改变的自动缩放。 首先,我们要理解Windows Forms和WPF这两个C#中的主要UI框架如何处理控件的大小调整。在Windows Forms中,可以通过设置控件的Anchor和Dock...

    winform窗体大小随分辨率改变

    在Windows Forms开发中,"winform窗体大小随分辨率改变"是一个常见的需求,它涉及到窗体的自动调整和响应式设计。窗体的大小和位置需要根据用户显示器的分辨率进行动态调整,以确保应用程序在不同尺寸的屏幕上都能...

    WPF 无边框拖动,并改变窗体大小

    总结起来,"WPF 无边框拖动,并改变窗体大小"涉及到的关键技术包括移除窗口边框,自定义拖动逻辑,以及实现窗口大小的自定义调整。这些技术可以帮助开发者构建更加灵活且符合用户交互习惯的无边框窗口应用。在实际...

    利用WPF建立自适应窗口大小布局的WinForm窗口[参照].pdf

    利用 WPF 建立自适应窗口大小布局的 WinForm 窗口 WPF(Windows Presentation Foundation)是一种基于 XML 的用户界面框架,用于构建 Windows 应用程序的用户界面。WinForm 是一种传统的 Windows 窗口应用程序开发...

    WPF控件大小随着窗体的改变而改变

    这一特性使得开发的程序具有更好的用户体验,因为用户可以根据自己的需求自由调整窗口大小,而界面元素仍能保持良好的可视性和可用性。 WPF提供了多种布局容器,如Grid、StackPanel、DockPanel和Canvas等,它们各自...

    mfc根据窗口大小自动调整所有控件大小

    在MFC(Microsoft Foundation Classes)框架中,设计用户界面时,有时我们需要实现窗口大小变化时,窗口内的控件能够自动调整大小以适应新的窗口尺寸。这个功能可以提供更好的用户体验,特别是当应用程序支持不同...

    visual c++设置设定窗口大小,并设置窗口不可以改变大小

    vc设置设定窗口大小,并设置窗口不可以改变大小

    delphi窗体内控件随窗体改变大小而自适应.zip

    通过学习和应用这些Delphi提供的特性,开发者可以创建出能够自适应窗口大小变化的用户界面,提高程序的视觉吸引力和用户体验。在压缩包"delphi窗体内控件随窗体改变大小而自适应.zip"中,很可能是包含了一个示例项目...

    VB窗体控件大小随窗体大小变化而变化

    `SaveFormPosition`和`RestoreFormPosition`函数用于保存和恢复窗体的位置状态,这在窗口最小化或最大化后很有用。 `DragForm`函数允许用户通过鼠标拖动窗体边缘来改变窗体大小,这通常在没有系统默认行为时使用。 ...

    vc++控制窗体大小

    如果你使用MFC(Microsoft Foundation Classes)库,可以重载`CWnd::OnSize`虚函数来处理窗口大小变化。在这个函数里,你可以根据新的大小调整子控件的位置和大小,以保持界面的布局。 7. **动态调整控件布局** ...

    VB 禁止调整MDI窗体大小.rar

    VB 禁止调整MDI窗体大小,窗体文件一共是2个,一个是主窗口文件,一个是MDI窗口文件,实现禁止改变窗口大小的功能,我们可以在MDIForm中当窗体加载时,,执行以下代码:  Private Sub MDIForm_Load()  Style = ...

    VB控件随窗体大小改变

    确保控件随窗体大小改变,不仅可以提供良好的用户界面体验,还能使应用程序更加适应不同的屏幕分辨率和窗口大小。 六、扩展与优化 除了使用基本的Resize事件和Anchor属性,还可以利用Layout事件、第三方控件库,...

Global site tag (gtag.js) - Google Analytics