Mobile Web开发基础之四--处理手机设备的横竖屏问题
发布时间 - 2026-01-11 02:44:37 点击率:次为了应对移动设备屏幕的碎片化,我们在开发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>
原英文网址:http://davidbcalhoun.com/2010/dealing-with-device-orientation
以上所述是小编给大家介绍的Mobile Web开发基础之四--处理手机设备的横竖屏问题,希望对大家有所帮助!
# mobile
# web
# 开发基础
# 手机设备
# 横竖屏
# Android实现横竖屏切换的实例代码
# 解决Android手机屏幕横竖屏切换
# 更靠谱的H5横竖屏检测方法(js代码)
# JS检测移动端横竖屏的代码
# javascript检测移动设备横竖屏
# 使用jQuery Mobile框架开发移动端Web App的入门教程
# jQuery mobile 移动web(4)
# jQuery mobile 移动web(6)
# 就会
# 来实现
# 就可以
# 也不
# 出了
# 两种
# 要做
# 英文
# 给大家
# 这个时候
# 仅是
# 不支持
# 所示
# 一个叫
# 这是一种
# 所述
# 回调
# 小编
# 之四
# 之比
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
微信小程序 input输入框控件详解及实例(多种示例)
如何快速上传建站程序避免常见错误?
Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】
PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
原生JS实现图片轮播切换效果
免费视频制作网站,更新又快又好的免费电影网站?
谷歌浏览器下载文件时中断怎么办 Google Chrome下载管理修复
如何在Windows服务器上快速搭建网站?
长沙做网站要多少钱,长沙国安网络怎么样?
laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析
实例解析angularjs的filter过滤器
javascript中对象的定义、使用以及对象和原型链操作小结
如何在Tomcat中配置并部署网站项目?
微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】
浅析上传头像示例及其注意事项
Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】
微信小程序 五星评分(包括半颗星评分)实例代码
如何获取上海专业网站定制建站电话?
如何快速搭建个人网站并优化SEO?
深圳网站制作的公司有哪些,dido官方网站?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
昵图网官网入口 昵图网素材平台官方入口
JS去除重复并统计数量的实现方法
如何用搬瓦工VPS快速搭建个人网站?
网站制作免费,什么网站能看正片电影?
JavaScript实现Fly Bird小游戏
高防服务器租用如何选择配置与防御等级?
如何快速配置高效服务器建站软件?
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
魔方云NAT建站如何实现端口转发?
如何在宝塔面板中修改默认建站目录?
如何快速查询网站的真实建站时间?
如何用花生壳三步快速搭建专属网站?
Laravel如何使用Sanctum进行API认证?(SPA实战)
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
高端建站三要素:定制模板、企业官网与响应式设计优化
Laravel如何使用模型观察者?(Observer代码示例)
昵图网官方站入口 昵图网素材图库官网入口
Python数据仓库与ETL构建实战_Airflow调度流程详解
动图在线制作网站有哪些,滑动动图图集怎么做?
Laravel如何实现用户密码重置功能?(完整流程代码)
香港服务器WordPress建站指南:SEO优化与高效部署策略
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
如何快速搭建高效服务器建站系统?
如何在景安云服务器上绑定域名并配置虚拟主机?
Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能
如何快速搭建自助建站会员专属系统?
Python文本处理实践_日志清洗解析【指导】
Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用

