前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >HTML5中判断横屏竖屏

HTML5中判断横屏竖屏

作者头像
山河木马
发布2019-03-05 17:40:46
4.6K0
发布2019-03-05 17:40:46
举报
文章被收录于专栏:山河木马

在移动端中我们经常碰到横屏竖屏的问题,那么我们应该如何去判断或者针对横屏、竖屏来写不同的代码呢。 首先在head中加入如下代码:

代码语言:javascript
复制
<meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>

针对上述viewport标签有如下说明 1)、content中的width指的是虚拟窗口的宽度。

2)、user-scalable=no就一定可以保证页面不可以缩放吗?NO,有些浏览器不吃这一套,还有一招就是minimum-scale=1.0, maximum-scale=1.0 最大与最小缩放比例都设为1.0就可以了。

3)、initial-scale=1.0 初始缩放比例受user-scalable控制吗?不一定,有些浏览器会将user-scalable理解为用户手动缩放,如果user-scalable=no,initial-scale将无法生效。

4)、手机页面可以触摸移动,但是如果有需要禁止此操作,就是页面宽度等于屏幕宽度是页面正好适应屏幕才可以保证页面不能移动。

5)、如果页面是经过缩小适应屏幕宽度的,会出现一个问题,当文本框被激活(获取焦点)时,页面会放大至原来尺寸。

一:CSS判断横屏竖屏

写在同一个CSS中

代码语言:javascript
复制
@media screen and (orientation: portrait) {   
    /*竖屏 css*/
}  
@media screen and (orientation: landscape) {
   /*横屏 css*/ 
}

分开写在2个CSS中 竖屏

代码语言:javascript
复制
@media screen and (orientation: portrait) {   /*竖屏 css*/ }  @media screen and (orientation: landscape) {   /*横屏 css*/ }

横屏

代码语言:javascript
复制
<link rel="stylesheet" media="all and (orientation:landscape)" href="landscape.css">

JS判断横屏竖屏

代码语言:javascript
复制
//判断手机横竖屏状态: 
window.addEventListener("onorientationchange" in window ? "orientationchange" : "resize", function() {
         if (window.orientation === 180 || window.orientation === 0) {
                       alert('竖屏状态!');         
         }          
         if (window.orientation === 90 || window.orientation === -90 ){
                       alert('横屏状态!');         
         }      
}, false);  
//移动端的浏览器一般都支持window.orientation这个参数,通过这个参数可以判断出手机是处在横屏还是竖屏状态。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017/07/03 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一:CSS判断横屏竖屏
  • JS判断横屏竖屏
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档