全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Mobile Web开发基础之四--处理手机设备的横竖屏问题

为了应对移动设备屏幕的碎片化,我们在开发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)  # 就会  # 来实现  # 就可以  # 也不  # 出了  # 两种  # 要做  # 英文  # 给大家  # 这个时候  # 仅是  # 不支持  # 所示  # 一个叫  # 这是一种  # 所述  # 回调  # 小编  # 之四  # 之比 


相关文章: 广州商城建站系统开发成本与周期如何控制?  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  Bpmn 2.0的XML文件怎么画流程图  济南网站制作的价格,历城一职专官方网站?  TestNG的testng.xml配置文件怎么写  公司网站设计制作厂家,怎么创建自己的一个网站?  网站制作软件免费下载安装,有哪些免费下载的软件网站?  济南企业网站制作公司,济南社保单位网上缴费步骤?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  ,网站推广常用方法?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  建站之星后台密码如何安全设置与找回?  建站之星24小时客服电话如何获取?  高防服务器如何保障网站安全无虞?  ui设计制作网站有哪些,手机UI设计网址吗?  如何在Golang中使用encoding/gob序列化对象_存储和传输数据  如何配置FTP站点权限与安全设置?  seo网站制作优化,网站SEO优化步骤有哪些?  七夕网站制作视频,七夕大促活动怎么报名?  如何选择高效稳定的ISP建站解决方案?  微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  定制建站如何定义?其核心优势是什么?  临沂网站制作企业,临沂第三中学官方网站?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  小型网站制作HTML,*游戏网站怎么搭建?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  专业公司网站制作公司,用什么语言做企业网站比较好?  建站主机助手选型指南:2025年热门推荐与高效部署技巧  北京专业网站制作设计师招聘,北京白云观官方网站?  在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  如何用wdcp快速搭建高效网站?  大连网站设计制作招聘信息,大连投诉网站有哪些?  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  常州企业建站如何选择最佳模板?  如何用PHP工具快速搭建高效网站?  如何使用Golang table-driven基准测试_多组数据测量函数效率  北京网站制作网页,网站升级改版需要多久?  如何在Tomcat中配置并部署网站项目?  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  如何通过建站之星自助学习解决操作问题?  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  重庆市网站制作公司,重庆招聘网站哪个好?  如何通过IIS搭建网站并配置访问权限?  微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?  焦点电影公司作品,电影焦点结局是什么?  定制建站是什么?如何实现个性化需求?  如何在阿里云虚拟服务器快速搭建网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。