移动端使用CSS或JS判断横屏和竖屏的讲解

 更新时间:2019年03月16日 11:54:15   作者:CODETC  
今天小编就为大家分享一篇关于移动端使用CSS或JS判断横屏和竖屏的讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

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

首先在head中加入如下代码:

<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中

@media screen and (orientation: portrait) {
 /*竖屏 css*/
} 
@media screen and (orientation: landscape) {
 /*横屏 css*/
}

分开写在2个CSS中

竖屏

<link rel="stylesheet" media="all and (orientation:portrait)" href="portrait.css" rel="external nofollow" >

横屏

<link rel="stylesheet" media="all and (orientation:landscape)" href="landscape.css" rel="external nofollow" >

二、JS判断横屏竖屏

//判断手机横竖屏状态:
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这个参数,通过这个参数可以判断出手机是处在横屏还是竖屏状态。

最近项目有电子合同方面的开发,需要电子签字,(用的jsignature插件,如果有空以后单独写个使用心得)。在手机小屏幕上签字,全屏横屏才是最好的体验。用户竖屏打开页面时要去签字,提示用户把手机横过来,这样体验太low了,程序员要考虑能用技术解决的就不要去劳烦用户(免得用户烦了回头打电话咬你)。

先来几个检测屏幕方向的方法:

//判断屏幕方向
if(window.orientation==90||window.orientation==-90){
  alert("横屏状态!")
}
//监听屏幕方向
window.onorientationchange = function(){ 
  switch(window.orientation){ 
    case -90: 
    case 90: 
      alert("横屏:" + window.orientation);
    case 0: 
    case 180: 
       alert("竖屏:" + window.orientation);
    break; 
  } 
} 
<!--css媒介查询判断-->
@media (orientation: portrait) { } 横屏
@media (orientation: landscape) { }竖屏 

进入网页检测是否横屏状态,不是就给canvas加样式:

transform: rotate(90deg);

最初想的是把jsignature的canvas画布用css3transform横过来就可以了,谁想到,画布横是过来了,touch相关的手势还是竖的(签字啊,笔画不跟手怎么签)。如果是普通项目仅仅是显示的话,上面的方法已经够用了。

还好这个项目是网页内嵌app中,app有方法强制网页横屏,改了改页面,交上去了。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

相关文章

  • 在Flutter中让文字Text换行的实现步骤

    在Flutter中让文字Text换行的实现步骤

    在Flutter中,Text小部件默认会尝试在其父小部件的约束内显示所有文本内容,如果父小部件没有提供足够的空间或没有设置约束限制,Text小部件可能无法正确换行,本文给大家介绍了在Flutter中如何让文字Text换行,需要的朋友可以参考下
    2024-07-07
  • android 中win10 使用uwp控件实现进度条Marquez效果

    android 中win10 使用uwp控件实现进度条Marquez效果

    这篇文章主要介绍了android 中win10 使用uwp控件实现进度条Marquez效果,需要的朋友可以参考下
    2017-06-06
  • android编程实现类似于支付宝余额快速闪动效果的方法

    android编程实现类似于支付宝余额快速闪动效果的方法

    这篇文章主要介绍了android编程实现类似于支付宝余额快速闪动效果的方法,涉及Android时间函数的相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • Android自定义webView头部进度加载效果

    Android自定义webView头部进度加载效果

    这篇文章主要介绍了Android自定义webView头部进度加载效果,小编画一条进度线,然后加载webview上面,具体实现代码大家参考下本文
    2017-11-11
  • Android底部导航栏的三种风格实现

    Android底部导航栏的三种风格实现

    这篇文章主要介绍了Android底部导航栏的三种风格实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Android 判断是否有外网连接

    Android 判断是否有外网连接

    本文给大家分享的是使用Android实现判断是否有外网链接,有需要的小伙伴可以参考下。
    2016-02-02
  • Android RecyclerView设置下拉刷新的实现方法

    Android RecyclerView设置下拉刷新的实现方法

    这篇文章主要介绍了Android RecyclerView设置下拉刷新的实现方法,希望通过本文通过SwipeRefreshLayout方式实现下拉刷新,需要的朋友可以参考下
    2017-10-10
  • Android简单实现文件下载

    Android简单实现文件下载

    这篇文章主要为大家详细介绍了Android简单实现文件下载,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • 图文详解Android Studio搭建Android集成开发环境的过程

    图文详解Android Studio搭建Android集成开发环境的过程

    这篇文章主要以图文的方式详细介绍了Android Studio搭建Android集成开发环境的过程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • Android SharedPreferences存取操作以及封装详解

    Android SharedPreferences存取操作以及封装详解

    SharedPreferences是安卓平台上一个轻量级的存储类,用来保存应用的一些常用配置,比如Activity状态,Activity暂停时,将此activity的状态保存到SharedPereferences中;当Activity重载,系统回调方法onSaveInstanceState时,再从SharedPreferences中将值取出
    2021-11-11

最新评论