web页面,强制横屏怎么处理

需求是页面必须横屏显示,但是页面制作时,是竖着的,又没有办法

阅读 8.2k
2 个回答

据我的观察,因为涉及到其它原生的界面(如输入框弹出键盘等),所以直接切换成横屏显示并不可取,比如使用css transform 等。

可以通过判断当前是否横竖屏,假若是竖屏状态,则提示用户必须在横屏显示才可获得最佳体验。让用户去选择横屏即可。这种做法貌似比较通用。

(另:假若是webview页面,是直接可以让ios或android开发强制webview页面横屏显示的)

clipboard.png

参考腾讯的活动页
js文件

var GYST = {
    //横竖屏判断
    landScape: function(option) {
        var _this = this;
        _this.option = {
            'pic': '',
            'mode': 'portrait',
            'bgcolor': '#333',
            'txtColor': '#FFFFFF',
            'prefix': 'page',
            'picZoom': 2,
            'zIndex': 9999999,
            'init': false,
            'landback': false
        };
        if (option.mode && option.mode != 'portrait') {
            _this.option.txt = '为了更好的体验,请使用横屏浏览'
        } else
            _this.option.txt = '为了更好的体验,请使用竖屏浏览';
        for (var k in option)
            if (option[k] != '')
                _this.option[k] = option[k];
        function createCss() {
            var cssBlock = '.' + _this.option.prefix + '-landscape{width:100%; height:100%; background:' + _this.option.bgcolor + ';position: fixed; left:0; right:0; top: 0; bottom:0;z-index:' + _this.option.zIndex + '; display:none; text-align: center;}.' + _this.option.prefix + '-landscape-box{position: relative; margin-left: auto; margin-right: auto; top: 50%; transform:translateY(-50%); -webkit-transform:translateY(-50%);}.' + _this.option.prefix + '-landscape span{font-size:16px;display:block;color:' + _this.option.txtColor + '; text-align:center;width: 100%;padding-top: 40px; line-height:2;}.' + _this.option.prefix + '-landscape img{-webkit-animation: ' + _this.option.prefix + '-landscapeAni 1.2s ease infinite alternate;animation: ' + _this.option.prefix + '-landscapeAni 1.2s ease infinite alternate;}@-webkit-keyframes ' + _this.option.prefix + '-landscapeAni{0% {-webkit-transform:rotate(90deg);}30% {-webkit-transform:rotate(90deg);}70%{-webkit-transform:rotate(0deg);}100% {-webkit-transform:rotate(0deg);}}@keyframes ' + _this.option.prefix + '-landscapeAni{0% {transform:rotate(90deg);}30% {transform:rotate(90deg);}70%{transform:rotate(0deg);}100% {transform:rotate(0deg);}}';
            var style = document.createElement("style");
            style.type = "text/css";
            style.textContent = cssBlock;
            document.getElementsByTagName("HEAD").item(0).appendChild(style)
        }
        function createDom() {
            var landscapeDom = document.createElement("div");
            landscapeDom.className = _this.option.prefix + '-landscape';
            landscapeDom.id = _this.option.prefix + '-landscape';
            landscapeDom.innerHTML = '<div class="' + _this.option.prefix + '-landscape-box"><img src="' + _this.option.pic + '" id="' + _this.option.prefix + '-landscape-pic" style="display:inline-block;" /><span>' + _this.option.txt + '</span></div>';
            document.body.appendChild(landscapeDom);
            var img_url = _this.pic;
            var img = new Image();
            img.src = _this.option.pic;
            img.onload = function() {
                document.getElementById(_this.option.prefix + '-landscape-pic').width = parseInt(img.width / _this.option.picZoom);
                document.getElementById(_this.option.prefix + '-landscape-pic').height = parseInt(img.height / _this.option.picZoom)
            }
        }
        createCss();
        createDom();

        var landNode = document.getElementById(_this.option.prefix + '-landscape');
        var optionMode = option.mode ? option.mode : _this.option.mode;
        var winW = document.documentElement.clientWidth || window.innerWidth;
        var winH = document.documentElement.clientHeight || window.innerHeight;
        var initOrientation = winW > winH ? 'landscape' : 'portrait';
        var isOrientationReload = initOrientation == optionMode ? false : true;
        if (initOrientation != optionMode)
            landNode.style.display = 'block';
        else
            landNode.style.display = 'none';

        var updateOrientation = function() {
            document.activeElement.blur();
            var orientation = window.orientation;
            switch (orientation) {
            case 90:
            case -90:
                orientation = 'landscape';
                break;
            default:
                orientation = 'portrait';
            }
            if (orientation != optionMode)
                landNode.style.display = 'block';
            else
                landNode.style.display = 'none';
        }
        window.addEventListener('DOMContentLoaded', function() {
            window.addEventListener('orientationchange', function() {
                if (isOrientationReload) {
                    location.reload(true);
                }
                updateOrientation();
            }, false);
        }, false);
    },
    _stopScroll: function() {
        event.preventDefault();
    },
    //禁止滚动
    disableScroll: function() {
        document.body.addEventListener('touchmove', this._stopScroll, {
            passive: false
        });
    },
    //恢复滚动
    enableScroll: function() {
        document.body.removeEventListener('touchmove', this._stopScroll);
    },
    //弹窗操作
    dialogAction: function(option) {
        var ths = this;
        var opt = {
            'rootEle': '#pageContainer',
            'wrapClass': '.mod-dialog-wrap',
            'openClass': '.j-openDialog',
            'closeClass': '.j-closeDialog'
        };
        for (var k in option)
            if (option[k] != '')
                opt[k] = option[k];

        $(opt.rootEle).on('click', opt.openClass, function() {
            var dg = $('#' + $(this).data('dialogid'));
            dg.show().addClass('show');
            if (dg.data('scroll') != 'scroll')
                ths.disableScroll();
        }).on('click', opt.closeClass, function() {
            var dg = $(this).closest(opt.wrapClass);
            dg.removeClass('show');
            if (dg.data('scroll') != 'scroll')
                ths.enableScroll();
        });
    }
};

$(function() {
    GYST.dialogAction({});
});
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题