html屏幕旋轉事件監聽


近期做微信服務號開發,在做圖片展示的時候需要橫豎屏的檢測實現圖片大小不同的展示。

添加屏幕旋轉事件偵聽,可隨時發現屏幕旋轉狀態(左旋、右旋還是沒旋)。

摘自:http://bbs.phonegap100.com/thread-28-1-1.html

//js 判斷屏幕是否旋轉

4. 屏幕旋轉事件:onorientationchange

添加屏幕旋轉事件偵聽,可隨時發現屏幕旋轉狀態(左旋、右旋還是沒旋)。例子:

// 判斷屏幕是否旋轉

function orientationChange() {

    switch(window.orientation) {

      case 0: 

            alert("肖像模式 0,screen-width: " + screen.width + "; screen-height:" + screen.height);

            break;

      case -90: 

            alert("左旋 -90,screen-width: " + screen.width + "; screen-height:" + screen.height);

            break;

      case 90:   

            alert("右旋 90,screen-width: " + screen.width + "; screen-height:" + screen.height);

            break;

      case 180:   

          alert("風景模式 180,screen-width: " + screen.width + "; screen-height:" + screen.height);

          break;

    };<br>};

// 添加事件監聽

addEventListener('load', function(){

    orientationChange();

    window.onorientationchange = orientationChange;

});

我們在開發Mobile Web應用時,一個最佳實踐就是采用流式布局,保證最大可能地利用有限的屏幕空間。

window.orientation屬性與onorientationchange事件    

window.orientation :這個屬性給出了當前設備的屏幕方向,0表示豎屏,正負90表示橫屏(向左與向右)模式

onorientationchange : 在每次屏幕方向在橫豎屏間切換后,就會觸發這個window事件,用法與傳統的事件類似

1、使用onorientationchange事件的回調函數,來動態地為body標簽添加一個叫orient的屬性,同時以body[orient=landspace]或body[orient=portrait]的方式在css中定義對應的樣式,這樣就可以實現在不同的屏幕模式下顯示不同的樣式。如下代碼示例:

<!Doctype html>  
    <html>  
        <head>  
            <meta charset="utf-8">  
            <meta id="viewport" name="viewport" content="width=device-width,initial-scale=1.0;">  
            <title>橫豎屏切換檢測</title>  
            <style type="text/css">  
                body[orient=landscape]{  
                    background-color: #ff0000;  
                }  
      
                body[orient=portrait]{  
                    background-color: #00ffff;  
                }  
            </style>  
        </head>  
        <body orient="landspace">  
            <div>  
                內容  
            </div>  
            <script type="text/javascript">  
                (function(){  
                    if(window.orient==0){  
                        document.body.setAttribute("orient","portrait");  
                    }else{  
                        document.body.setAttribute("orient","landscape");  
                    }  
                })();  
                window.onorientationchange=function(){  
                    var body=document.body;  
                    var viewport=document.getElementById("viewport");  
                    if(body.getAttribute("orient")=="landscape"){  
                        body.setAttribute("orient","portrait");  
                    }else{  
                        body.setAttribute("orient","landscape");  
                    }  
                };  
            </script>  
        </body>  
    </html>  

2、類似的思路,不通過CSS的屬性選擇器來實現,如下代碼的實現方案:

<!Doctype html>  
    <html>  
        <head>  
            <meta charset="utf-8">  
            <meta id="viewport" name="viewport" content="width=device-width,initial-scale=1.0;">  
            <title>橫豎屏切換檢測</title>  
            <style type="text/css">  
                .landscape body {  
                    background-color: #ff0000;  
                }  
      
                .portrait body {  
                    background-color: #00ffff;  
                }  
            </style>  
        </head>  
        <body orient="landspace">  
            <div>  
                內容  
            </div>  
            <script type="text/javascript">  
                (function(){  
                    var init=function(){  
                        var updateOrientation=function(){  
                            var orientation=window.orientation;  
                            switch(orientation){  
                                case 90:   
                                case -90:  
                                    orientation="landscape";  
                                    break;  
                                default:  
                                    orientation="portrait";  
                                    break;  
                            }  
                            document.body.parentNode.setAttribute("class",orientation);  
                        };  
      
                        window.addEventListener("orientationchange",updateOrientation,false);  
                        updateOrientation();  
                    };  
                    window.addEventListener("DOMContentLoaded",init,false);  
                })();  
            </script>  
        </body>  
    </html>  

使用media query方式

    這是一種更為方便的方式,使用純CSS就實現了對應的功能,如下代碼演示:

<!Doctype html>  
    <html>  
        <head>  
            <meta charset="utf-8">  
            <meta id="viewport" name="viewport" content="width=device-width,initial-scale=1.0;">  
            <title>橫豎屏切換檢測</title>  
            <style type="text/css">  
                @media all and (orientation : landscape) {  
                    body {   
                        background-color: #ff0000;   
                    }  
                }  
      
                @media all and (orientation : portrait){  
                    body {  
                        background-color: #00ff00;  
                    }  
                }  
            </style>  
        </head>  
        <body>  
            <div>  
                內容  
            </div>  
        </body>  
    </html>  

低版本瀏覽器的平穩降級

     如果目標移動瀏覽器不支持media query,同時window.orientation也不存在,則我們需要采用另外一種方式來實現————使用定時器“偽實時”地對比當前窗口的高(window.innerHeight)與寬(window.innerWidth)之比,從而判定當前的橫豎屏狀態。如下代碼所示:

<!Doctype html>  
    <html>  
        <head>  
            <meta charset="utf-8">  
            <meta id="viewport" name="viewport" content="width=device-width,initial-scale=1.0;">  
            <title>按鍵</title>  
            <style type="text/css">  
                .landscape body {  
                    background-color: #ff0000;  
                }  
      
                .portrait body {  
                    background-color: #00ffff;  
                }  
            </style>  
            <script type="text/javascript">  
                (function(){  
                    var updateOrientation=function(){  
                        var orientation=(window.innerWidth > window.innerHeight)? "landscape" : "portrait";  
                        document.body.parentNode.setAttribute("class",orientation);  
                    };  
      
                    var init=function(){  
                        updateOrientation();  
                        window.setInterval(updateOrientation,5000);  
                    };  
                    window.addEventListener("DOMContentLoaded",init,false);  
                })();  
            </script>  
        </head>  
        <body>  
            <div>  
                內容  
            </div>  
        </body>  
    </html>  

統一解決方案

將以上的兩種解決方案整合在一起,就可以實現一個跨瀏覽器的解決方案,如下代碼:

    <!Doctype html>  
    <html>  
        <head>  
            <meta charset="utf-8">  
            <meta id="viewport" name="viewport" content="width=device-width,initial-scale=1.0;">  
            <title>橫豎屏切換檢測</title>  
            <style type="text/css">  
                .landscape body {  
                    background-color: #ff0000;  
                }  
      
                .portrait body {  
                    background-color: #00ffff;  
                }  
            </style>  
            <script type="text/javascript">  
                (function(){  
                    var supportOrientation=(typeof window.orientation == "number" && typeof window.onorientationchange == "object");  
      
                    var updateOrientation=function(){  
                        if(supportOrientation){  
                            updateOrientation=function(){  
                                var orientation=window.orientation;  
                                switch(orientation){  
                                    case 90:  
                                    case -90:  
                                        orientation="landscape";  
                                        break;  
                                    default:  
                                        orientation="portrait";  
                                }  
                                document.body.parentNode.setAttribute("class",orientation);  
                            };  
                        }else{  
                            updateOrientation=function(){  
                                var orientation=(window.innerWidth > window.innerHeight)? "landscape":"portrait";  
                                document.body.parentNode.setAttribute("class",orientation);  
                            };  
                        }  
                        updateOrientation();  
                    };  
      
                    var init=function(){  
                        updateOrientation();  
                        if(supportOrientation){  
                            window.addEventListener("orientationchange",updateOrientation,false);  
                        }else{      
                            window.setInterval(updateOrientation,5000);  
                        }  
                    };  
                    window.addEventListener("DOMContentLoaded",init,false);  
                })();  
            </script>  
        </head>  
        <body>  
            <div>  
                內容  
            </div>  
        </body>  
    </html>  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM