中文字幕理论片,69视频免费在线观看,亚洲成人app,国产1级毛片,刘涛最大尺度戏视频,欧美亚洲美女视频,2021韩国美女仙女屋vip视频

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
關(guān)于移動端頁面強制豎屏的方法

最近工作中寫了一個移動端的頁面,本來是沒什么的,但是有一個要求感覺很奇怪,從前也沒有遇到過,就是我寫的這個頁面需要放在一個APP中,但是這個APP是橫屏的,打開這個頁面的webview也是橫屏的(最新版的APP打開的時候是豎屏的webview),本來我們是用的rem布局,橫屏的狀態(tài)下也是沒有什么問題的,但是甲方希望在橫屏打開的時候強制這個頁面豎屏顯示。所以就有了下面一系列的操作了。
首先是判斷橫屏的狀態(tài),使用的一下的代碼:
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
function orient() {
            if(window.orientation == 90 || window.orientation == -90) {//橫屏
                //ipad、iphone豎屏;Andriod橫屏
                //$("body").attr("class", "landscape");
                //orientation = 'landscape';
                //alert("ipad、iphone豎屏;Andriod橫屏");
                $("p").text("橫屏");
                return false;
            } else if(window.orientation == 0 || window.orientation == 180) {//豎屏
                //ipad、iphone橫屏;Andriod豎屏
//                $("body").attr("class", "portrait");
//                orientation = 'portrait';
                //alert("ipad、iphone橫屏;Andriod豎屏");
                $("p").text("豎屏");
                return false;
            }
        }
        //頁面加載時調(diào)用
        $(function() {
            orient();
        });
        //用戶變化屏幕方向時調(diào)用
        $(window).on('orientationchange', function(e) {
            
            orient();
            
        });
這個就是在監(jiān)測手機的方向。但是,因為打開的這個APP的時候就是橫屏打開的,多以這個是沒辦法監(jiān)測到的,而且這個還有一個前提就是手機必須打開了自動旋轉(zhuǎn)才是可以的。所以上面的方法被拋棄了。
既然智能的辦法被拋棄了,那就用最賤的辦法,就是監(jiān)測屏幕的寬度和高度。當高大于寬的時候,我們默認手機是豎屏的狀態(tài),當寬大于高的時候,我們認為是橫屏的狀態(tài)。(當然了這個也是有局限的,但是考慮到新的APP中已經(jīng)把橫豎屏的問題解決了,這里就姑且這么做了)。當豎屏的狀態(tài)我們是不需要做什么的。但是在橫屏的狀態(tài)下,我們就要把頁面轉(zhuǎn)動90度了。廢話不多說,直接看代碼:
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
// 利用 CSS3 旋轉(zhuǎn) 對根容器逆時針旋轉(zhuǎn) 90 度 強制用戶進行豎屏顯示
var detectOrient = function() {
    var width = document.documentElement.clientWidth,
        height = document.documentElement.clientHeight,
        //$wrapper = document.getElementsByTagName("body")[0],
        $wrapper = document.getElementById("vue"),
        style = "";
    if(width <= height) { // 橫屏
//        style += "width:" + width + "px;"; // 注意旋轉(zhuǎn)后的寬高切換
//        style += "height:" + height + "px;";
//        style += "-webkit-transform: rotate(0); transform: rotate(0);";
//        style += "-webkit-transform-origin: 0 0;";
//        style += "transform-origin: 0 0;";
        style += "font-size:" + (width * 100 / 1125) + "px";
        var html_doc = document.getElementsByTagName("html")[0];
        html_doc.style.cssText = "font-size:" + (width * 100 / 1125) + "px";
    } else { // 豎屏
        style += "width:" + height + "px;";
        style += "min-height:" + width + "px;";
        style += "-webkit-transform: rotate(-90deg); transform: rotate(-90deg);";
        // 注意旋轉(zhuǎn)中點的處理
        style += "-webkit-transform-origin: " + height / 2 + "px " + (height / 2) + "px;";
        style += "transform-origin: " + height / 2 + "px " + (height / 2) + "px;";
        //style += "font-size:" + height * 100 / 1125 + "px;";
        //$("html").css({"font-size":(height * 100 / 1125),"overflow-y":"hidden"});
        var html_doc = document.getElementsByTagName("html")[0];
        html_doc.style.cssText = "font-size:" + height * 100 / 1125 + "px;" + "overflow-y:"+"hidden;"+"height:"+height+"px;";
        style += "overflow-y: hidden;";
        add_tab();
        $wrapper.style.cssText = style;
    }
    
    
}
window.onresize = detectOrient;
detectOrient();
 
function add_tab(){
    var clone_tab = $("footer").clone();
    $("footer").remove();
    clone_tab.css({"transform":"rotate(-90deg)","transform-origin":"top right"})
    $("body").append(clone_tab);
    clone_tab.css({"position":"fixed","right":"1.77rem","bottom":"4rem","left":"auto","top":"0","width":"11.25rem","height":"1.77rem"})
}
相信這段代碼對于前端人員來說不是很難,但是有一點需要注意的有三點。
第一點:
最開始的時候我是為了方便直接旋轉(zhuǎn)的整個的html,這個是時候會有一個問題,就是頁面中的fixed定位的元素,定位就不管用了(代碼中的<footer>就是作為tab切換放在底部的);這個就需要我們更改了,既然旋轉(zhuǎn)父元素,子元素就不管用了,那我們就不要旋轉(zhuǎn)父元素了,直接旋轉(zhuǎn)他的兄弟元素就可以了。我這里是旋轉(zhuǎn)的一個叫做#vue的元素,因為我的頁面中的其他的內(nèi)容全部是在這個div當中的。所以我就旋轉(zhuǎn)了這個元素。然后這個時候定位是可以用的,但是樣式不對,所以在我的add_tab這個函數(shù)中就是在調(diào)整這個元素的大小和樣式,讓他能正常的顯示在屏幕的右側(cè),也就是豎屏的狀態(tài)下,屏幕的底端。
第二點:
第二點需要注意的是,應為我用的是rem布局,多以我會更改html的font-size,但是這個時候就要小心了,當我們旋轉(zhuǎn)過來之后,寬變成了高,高變成了寬,所以我們需要用height來計算根目錄的字體大小。
第三點:
第三點就是在程序中注明的,需要我們注意旋轉(zhuǎn)的中心,默認的旋轉(zhuǎn)中心是在所選元素的中心點。多以我們要改變旋轉(zhuǎn)的中心點。旋轉(zhuǎn)之后還要把html的overflow-y:hidden。否則就會出現(xiàn)多余的滾動。
這樣的話,基本上就把整個頁面旋轉(zhuǎn)過來了,并且把底部的fixed定位的元素再次定位成功了。比較幸運的是我們用的彈窗是用的layui的彈窗,再把這個彈窗旋轉(zhuǎn)90度就可以了。
ps:最后發(fā)現(xiàn)一點問題是沒辦法解決的,就是當頁面夠長的時候,也就是有滾動條的時候,彈窗出來以后,滑動后面的遮罩層的話,后面的頁面會向上滑動。這個本來是可以解決的,我上面的這個文章就是利用fixed定位解決的,但是因為旋轉(zhuǎn)了,這個失效了,所以就沒有好的辦法了。在豎屏狀態(tài)下是沒問題的。

本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
JS彈窗 JS彈出DIV并使整個頁面背景變暗功能的實現(xiàn)代碼
愛的痕跡(陳瑞最動聽的傷感歌曲50首)
div中的內(nèi)容垂直居中的五種方法
頁面跳轉(zhuǎn)
【聊代碼】第一三五集 同步歌詞(十二)單曲單行歌詞逐字變色
春色無邊
更多類似文章 >>
生活服務(wù)
熱點新聞
分享 收藏 導長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服