移动端H5页面兼容性问题小结

1. input框 边框的在ios下颜色变淡问题

input:disabled{

     border: 1px solid #017BBA;

      -webkit-opacity:1;

       opacity: 1;

}

2. iphone7下 横屏之后字体变大

  css中加入以下代码:

@media screen and (max-device-width: 320px){body{-webkit-text-size-adjust:100%}}
@media screen and (max-device-width: 480px){body{-webkit-text-size-adjust:100%}}
@media only screen and (-webkit-min-device-pixel-ratio: 2){body{-webkit-text-size-adjust:100%}}
如何没有效果,就单独在标签上设置样式 -webkit-text-size-adjust:100%
3. H5页面禁止横屏 

uc浏览器强制竖屏

<meta name="screen-orientation" content="portrait">

 QQ浏览器强制竖屏

<meta name="x5-orientation" content="portrait">

iphone safari浏览器没有查到可以使用meta,以上应该会有兼容性问题(没有测),我是使用的是js方法,当横屏的时候显示一个页面,告诉用户“为了您的良好体验,请使用竖屏”

js方式

   
 1 (function rotate(){
 2     var orientation=window.orientation;
 3     var pd = null;
 4     function createPd(){
 5         if(document.getElementById('preventTran') === null){
 6              var imgData = '';
 7              pd = document.createElement('div');
 8              pd.setAttribute('id','preventTran');
 9              pd.style.position = 'fixed';
10              pd.style.left = '0';
11              pd.style.top = '0';
12              pd.style.width = '100%';
13              pd.style.height = '100%';
14              pd.style.overflow = 'hidden';
15              pd.style.backgroundColor = '#2e2e2e';
16              pd.style.textAlign = 'center';
17              pd.style.zIndex = '99999';
18              document.getElementsByTagName('body')[0].appendChild(pd);
19              var img = document.createElement('img');
20              img.src = imgData;
21              pd.appendChild(img);
22              img.style.margin = '60px auto 30px'
23              var br = document.createElement('br');
24              var p = document.createElement('p');
25              p.style.width = '100%';
26              p.style.height = 'auto';
27              p.style.fontSize = '18px';
28              p.style.color = '#626262';
29              p.style.lineHeight = '22px';
30              p.style.textAlign = 'center';
31              p.innerHTML = '为了您的良好体验';
32              p.appendChild(br);
33              p.innerHTML += '请将手机竖屏操作';
34              pd.appendChild(p);
35          }
36     }
37     var domArr = $('body').children().not('script').not('#preventTran');
38     if(orientation==90||orientation==-90){
39          if(pd == null && document.getElementById('preventTran') === null) createPd();
40          document.getElementById('preventTran').style.display = 'block';
41        // 以下代码为了解决横屏显示时出现用户依旧可以看到页面并且页面可以滑动
42          for(var i = 0; i < domArr.length; i++){
43              if($(domArr[i]).is(':visible')){
44                  if(!$(domArr[i]).children("canvas")){
45                     $(domArr[i]).addClass('rotateScreenClass');
46                  }
47                 
48              }
49          }
50         
51        
52       
53     }else{
        // 以下代码为了解决横屏显示时用户依旧可以看到页面并且可以滑动页面问题
54 for(var i = 0; i < domArr.length; i++){ 55 if($(domArr[i]).hasClass("rotateScreenClass")){ 56 $(domArr[i]).removeClass('rotateScreenClass'); 57 } 58 } 59 } 60 window.onorientationchange=function(){ 61 if(pd == null && document.getElementById('preventTran') == null) createPd(); 62 document.getElementById('preventTran').style.display='none'; 63 rotate(); 64 }; 65 })();

css中需添加一个样式:

       .rotateScreenClass{

            display: none;

        }

 4.  ORC上传身份证正反面时,如果用户手机水平与地面拍照时,横屏或者竖屏拍身份证会出现上传的图片显示不正常(还没解决。。。)
  试过的方法:引入exif.js,获取到Orientation的值,根据Orientation的值进行判断旋转
  此种方法适用于手机垂直或与地面有角度时,即当手机水平与地面拍照时,是没有横屏和竖屏之分的,没有办法判断方向
 5 . 待续
posted @ 2020-03-05 17:11  一朵小红花~  阅读(1680)  评论(0编辑  收藏  举报