ChatGPT解决这个技术问题 Extra ChatGPT

使用 jQuery 获取视口大小

如何使用 jQuery 确定浏览器视口的大小,并在调整页面大小时重新检测?我需要在这个空间中设置一个 IFRAME 大小(每个边距都有一点)。

对于那些不知道的人,浏览器视口不是文档/页面的大小。它是滚动前窗口的可见大小。

知道如何获取设备屏幕上可见的区域,而不仅仅是它可以滚动到的区域吗?我看到 $(window).height() 返回文档的完整宽度,而不是缩放到的部分。我想知道应用缩放后有多少可见。
appelsiini.net/projects/viewport 应该这样做! :)
这不是问题的直接答案,但对于那些想要根据他们的位置来操纵选择器的人来说很方便。相对于视口的可见性:appelsiini.net/projects/viewport(插件)

S
SimaWB

要获取视口的宽度和高度:

var viewportWidth = $(window).width();
var viewportHeight = $(window).height();

页面调整大小事件:

$(window).resize(function() {

});

我在 Windows IE6、IE8、FF3.6.3、Google Chrome 5.0.375.70、Opera 10.53 和 Safari 5.0 (7533.16) 上对此进行了测试。这对所有这些都有效。我还在 Ubuntu 上测试了 FF3.6.3,它也可以在那里工作。我想我正在使用 jQuery 1.3 和 WordPress 2.9.2,这是我需要它工作的地方。
知道如何获取设备屏幕上可见的区域,而不仅仅是它可以滚动到的区域吗?我看到 $(window).height() 返回文档的完整宽度,而不是缩放到的部分。我想知道应用缩放后有多少可见。
实际上,innerWidth / innerHeight 使用起来更正确(包括缩放)。
@FrankSchwieterman 也许您的浏览器没有按照您希望的方式运行:也许您遇到了这个问题: stackoverflow.com/q/12103208/923560 。确保您的 HTML 文件包含正确的 DOCTYPE 声明,例如 <!DOCTYPE html>
这是完全错误的。这为您提供了文档的大小,而不是视口(文档上的窗口大小)。
V
Vitalii Fedorenko

您可以尝试 viewport units (CSS3):

div { 
  height: 95vh; 
  width: 95vw; 
}

Browser support


g
gdoron is supporting Monica

1. 对主要问题的回应

脚本 $(window).height() 运行良好(显示视口的高度,而不是具有滚动高度的文档),但它需要您在文档中正确放置 doctype 标签,例如这些 doctype:

对于 HTML 5:

<!DOCTYPE html>

对于过渡 HTML4:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

可能某些浏览器假定的默认文档类型是这样的,即 $(window).height() 采用文档的高度而不是浏览器的高度。使用 doctype 规范,它得到了令人满意的解决,我很确定你会避免“将滚动溢出更改为隐藏然后返回”,对不起,这是一个有点肮脏的技巧,特别是如果你不这样做' t 将其记录在代码中以供将来程序员使用。

2. 附加提示,请注意:此外,如果您正在编写脚本,您可以发明测试来帮助程序员使用您的库,让我发明几个:

$(文档).ready(函数() {

      if(typeof $=='undefined') {
        alert("PROGRAMMER'S Error: you haven't called JQuery library");
      } else if (typeof $.ui=='undefined') {
        alert("PROGRAMMER'S Error: you haven't installed the UI Jquery library");
      }
      if(document.doctype==null || screen.height < parseInt($(window).height()) ) {
        alert("ERROR, check your doctype, the calculated heights are not what you might expect");
      } 

});

编辑:关于第 2 部分,“附加提示,请注意”:@Machiel,在昨天的评论(2014-09-04)中,完全正确:$ 的检查不能在 Jquery 的 ready 事件中,因为正如他所指出的,我们假设 $ 已经定义。感谢您指出这一点,如果您在脚本中使用它,请其他读者更正这一点。我的建议是:在您的库中放置一个初始化库的“install_script()”函数(在此类 init 函数中放置对 $ 的任何引用,包括 ready() 的声明)并在此类“install_script()”函数的开头,检查 $ 是否已定义,但使所有内容都独立于 JQuery,因此您的库可以在 JQuery 尚未定义时“自我诊断”。我更喜欢这种方法,而不是强制从 CDN 中自动创建 JQuery。这些只是帮助其他程序员的小笔记。我认为制作库的人必须对潜在的程序员错误的反馈更丰富。例如,Google API 需要一个辅助手册来理解错误消息。这是荒谬的,需要外部文档来解决一些不需要你去搜索手册或规范的小错误。库必须是自记录的。我编写代码时甚至会考虑到六个月后我可能会犯的错误,并且它仍然试图成为一个干净且不重复的代码,已经编写以防止未来的开发人员错误。


阅读您的帖子非常困难。请重做您的帖子,以便您像其他人一样习惯 StackExchange Markdown。有 a reason why StackExchange sites do not use TinyMCE,但如果您对此感到不满,请参与 Meta
在您已经使用 $ 调用 $(document).ready(function() { } ); 之后检查 $ 的可用性有点奇怪。如果您检查 jQuery 是否可用,这很好,但此时已经为时已晚。
@Machiel,您完全正确。幸运的是,我只是去检查了我的脚本,它们没有使用 ready 事件。是的,谢谢,当你这么说的时候我觉得很愚蠢,但幸运的是,我刚刚在我的脚本中检查了检查是在一个名为“install_this_script()”的函数中进行的,在这种安装中,我调用了库的 init 函数,但是在此之前,我检查 (OUTSIDE JQUERY) 是否定义了 $ 对象。无论如何,谢谢,兄弟,你真的把我吓坏了!恐怕这篇文章在这里太长了,我希望这个错误没有对其他读者造成太大的伤害。我更正了帖子。
这应该是真正的答案!谢谢!
f
forsvunnet

您可以使用 $(window).resize() 来检测视口是否已调整大小。

当存在滚动条时,jQuery 没有任何功能来一致地检测视口 [1] 的正确宽度和高度。

我找到了一个使用 Modernizr 库的解决方案,特别是打开 javascript 媒体查询的 mq 函数。

这是我的解决方案:

// A function for detecting the viewport minimum width.
// You could use a similar function for minimum height if you wish.
var min_width;
if (Modernizr.mq('(min-width: 0px)')) {
    // Browsers that support media queries
    min_width = function (width) {
        return Modernizr.mq('(min-width: ' + width + ')');
    };
}
else {
    // Fallback for browsers that does not support media queries
    min_width = function (width) {
        return $(window).width() >= width;
    };
}

var resize = function() {
    if (min_width('768px')) {
        // Do some magic
    }
};

$(window).resize(resize);
resize();

我的回答可能无助于将 iframe 的大小调整为 100% 视口宽度,并且每边都有一个边距,但我希望它能为因浏览器不连贯的 javascript 视口宽度和高度计算而感到沮丧的 web 开发人员提供安慰。

也许这对 iframe 有帮助:

$('iframe').css('width', '100%').wrap('<div style="margin:2em"></div>');

[1] 您可以使用 $(window).width() 和 $(window).height() 来获取在某些浏览器中正确但在其他浏览器中不正确的数字。在这些浏览器中,您可以尝试使用 window.innerWidth 和 window.innerHeight 来获得正确的宽度和高度,但我建议不要使用这种方法,因为它依赖于用户代理嗅探。

通常,不同的浏览器在是否将滚动条作为窗口宽度和高度的一部分包含在内时是不一致的。

注意:$(window).width() 和 window.innerWidth 在使用相同浏览器的操作系统之间会有所不同。请参阅:https://github.com/eddiemachado/bones/issues/468#issuecomment-23626238


A
AnuRaj
function showViewPortSize(display) {
    if (display) {
        var height = window.innerHeight;
        var width = window.innerWidth;
        jQuery('body')
            .prepend('<div id="viewportsize" style="z-index:9999;position:fixed;bottom:0px;left:0px;color:#fff;background:#000;padding:10px">Height: ' + height + '<br>Width: ' + width + '</div>');
        jQuery(window)
            .resize(function() {
                height = window.innerHeight;
                width = window.innerWidth;
                jQuery('#viewportsize')
                    .html('Height: ' + height + '<br>Width: ' + width);
            });
    }
}
$(document)
    .ready(function() {
        showViewPortSize(true);
    });

使用 $(window).height() 不会给你视口大小,它会给你整个窗口的大小,这通常是整个文档的大小,尽管文档可能更大。
非常适合宽度!
S
SandroMarques

要在加载和调整大小时获取视口大小(基于 SimaWB 响应):

function getViewport() {
    var viewportWidth = $(window).width();
    var viewportHeight = $(window).height();
    $('#viewport').html('Viewport: '+viewportWidth+' x '+viewportHeight+' px');
}

getViewport();

$(window).resize(function() {
    getViewport()
});

D
D.A.H

请注意 CSS3 视口单位 (vh,vw) 在 iOS 上无法正常播放当您滚动页面时,视口大小会以某种方式重新计算,并且使用视口单位的元素的大小也会增加。因此,实际上需要一些 javascript。