如何动态检测浏览器视口大小的变化?

时间:2015-02-24 15:07:20

标签: javascript jquery html css scaling

我一直遇到缩放问题...自动...动态...自适应......等等......

我看过网站,因为你把窗户做得更小了,例如。抓住一个角落,让窗户变小,字体变大,东西四处移动......

我有动作部分,我不知道如何动态检测浏览器视口......是一件令人耳目一新的事情还是?...

正如你在这里看到的,我用过的这些动作只能用于屏幕刷新,特别是我有一个平板电脑,如果我在横向访问页面,它就不适用;如果我旋转它然后刷新,它适用。

<script language="JavaScript" type="text/javascript">
var x = screen.width;
var y = screen.height;
function scale() {
var z = x/y;
    if (z<1) {
     document.getElementById('header').style.width = "100%";
     document.getElementById('menu').style.marginLeft = "0";
     document.getElementById('menu').style.width = "20%";
     document.getElementById('menu2').style.width = "30%";
     document.getElementById('menu3').style.width = "20%";
     document.getElementById('menu4').style.width = "20%";
     document.getElementById('properties').style.width = "30%";
     document.getElementById('properties').style.marginLeft = "35%";
    }
}
scale();
</script>

这是Stack Overflow关于字体的人提供的代码,我想它可能类似于我要去的方向

$( window ).resize(function() {
    $( "#container" ).css("font-size",function() {
        var value = $( "#container" ).css("width");
        console.log(parseInt(value)/24 + "pt");
        return parseInt(value)/24 + "pt";
    }) ;
});

哪一部分是动态的?

这个console.log,我之前没用过

任何帮助都会非常感激

1 个答案:

答案 0 :(得分:9)

在阅读了你的问题和评论后,我仍然有点困惑,但也许这会有所帮助。

首先,学会使用Chrome's Dev Tools。它们 awesome !你现在最需要知道的是:

使用console.log

  1. 在JavaScript中,写一行console.log('Hello World!');
  2. Google Chrome
  3. 中打开该页面
  4. F12 切换(打开/关闭)DevTools
  5. 它可能位于Resources标签上,这是检查所有资源已加载的好地方,但不是您正在寻找的资源。
  6. 点击标有Console
  7. 的标签
  8. 中提琴!如果该JS行已运行,您应该看到Hello World!
  9. 欢迎来到awesomsauce!
  10. 现在关于调整大小测试的更简单的视觉效果,请尝试以下jQuery增强的JavaScript :(评论说明,如果您愿意,请删除评论)

    //  This first line is the same as JavaScript's `document.ready = function() {}
    //  This simply starts your code running as soon as the document is loaded and ready to go
    //  It's safe to use in <head> or in <body> and will always ensure your JS is running with the page load
    $(function() {
        //  Here I use .on instead of direct reference to the event as this is just good practice4 with jQuery
        //  You'll later learn you can use this with prewritten methods to "turn on/off" methods asigned to specific events
        $(window).on('resize', function(e) {
            //  Little JS Tip, No need to write `var` 50thousand times. Just use a comma and write your new variable
            var x = $(this).width(),    //  variable for window width assigned to `x`
                y = $(this).height(),   //  variable for window height assigned to `y`
                z = x/y,    //  your conversion you were using in the code you have in your question, there's plenty of different ways to test for size changes, do some Googling on "aspect ratio" as it's usually best way to go
                //  this next line is a little complicated
                //  It's assigning a variable based on result of an `inline if statement`
                //  What it says: if (element with id 'myOutput' exist) then assign that element and empty it of all it's HTML, else build the element using jQuery's element object method and append it to the <body>
                //  jQuery's element object building is easy, just remember it like this: jQuery("<tagName />", { object of attributes })
                output = $('#myOutput').length ? $('#myOutput').empty() : $('<div />', { id: 'myOutput', style: 'background: #ffa; padding: 10px; position: fixed; right: 30px; top: 30px; z-index: 999;' }).appendTo('body'),
                //  the following lines build the inner HTML for showing the results of our window dimensions
                pX = $('<p />', { text: 'x: '+x }).appendTo(output),
                pY = $('<p />', { text: 'y: '+y }).appendTo(output),
                pZ = $('<p />', { text: 'z: '+z.toFixed(5) }).appendTo(output);
        });
    })
    

    如果您现在正在使用Google Chrome,那么您现在就可以测试它!只需按F12,然后点击Console标签即可。复制下面的最小化代码,然后单击Console。您应该看到一个闪烁的光标准备输入。粘贴代码并按Enter键!然后只需调整窗口大小并观看右上角! * note 位于最右侧,您可能会看到Chrome自带的尺寸框。我的黄色背景

    缩小代码:

    $(function(){$(window).on("resize",function(a){a=$(this).width();var c=$(this).height(),d=a/c,b=$("#myOutput").length?$("#myOutput").empty():$("<div />",{id:"myOutput",style:"background: #ffa; padding: 10px; position: fixed; right: 30px; top: 30px; z-index: 999;"}).appendTo("body");$("<p />",{text:"x: "+a}).appendTo(b);$("<p />",{text:"y: "+c}).appendTo(b);$("<p />",{text:"z: "+d.toFixed(5)}).appendTo(b)})});