需求是页面必须横屏显示,但是页面制作时,是竖着的,又没有办法
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({});
});
10 回答11.1k 阅读
6 回答3k 阅读
5 回答4.8k 阅读✓ 已解决
4 回答3k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
3 回答5.1k 阅读✓ 已解决
5 回答1.9k 阅读
据我的观察,因为涉及到其它原生的界面(如输入框弹出键盘等),所以直接切换成横屏显示并不可取,比如使用
css transform
等。可以通过判断当前是否横竖屏,假若是竖屏状态,则提示用户必须在横屏显示才可获得最佳体验。让用户去选择横屏即可。这种做法貌似比较通用。
(另:假若是webview页面,是直接可以让ios或android开发强制webview页面横屏显示的)