久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

移動端使用CSS或JS判斷橫屏和豎屏的講解

今天小編就為大家分享一篇關于移動端使用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有方法強制網頁橫屏,改了改頁面,交上去了。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對html5模板網的支持。如果你想了解更多相關內容請查看下面相關鏈接

【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!

相關文檔推薦

主站蜘蛛池模板: 色资源在线视频 | 午夜影院在线观看 | 午夜免费观看体验区 | 91精品国产色综合久久不卡蜜臀 | 波多野结衣精品 | 免费一区| 国产精品揄拍一区二区 | 久久久精品综合 | 亚洲一区免费 | 99视频在线免费观看 | 欧美久久一区二区三区 | 成人在线观看亚洲 | 久久久久国产一区二区 | 国产一区二区欧美 | 色婷婷九月| 日日操夜夜干 | 精品视频在线观看 | 亚洲久久一区 | 欧美日韩一区二区视频在线观看 | 日韩在线不卡 | japanhd成人 | 国产精品一区二区三 | 日本不卡免费新一二三区 | 国产精品一区在线 | 在线播放中文字幕 | 久久99一区二区 | 好婷婷网 | 超碰97人人人人人蜜桃 | 天堂中文av | 日韩高清成人 | 国产成人综合亚洲欧美94在线 | 亚洲成网 | 成人国产精品入口免费视频 | 国产精品久久久久久久久久久久午夜片 | 国产精品不卡一区 | 久久久成人免费一区二区 | 欧美日韩不卡合集视频 | 国产精品毛片 | 国产aⅴ爽av久久久久久久 | av免费电影在线 | 国产亚洲精品久久久久久豆腐 |