成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

移動(dòng)端使用CSS或JS判斷橫屏和豎屏的講解

在移動(dòng)端中我們經(jīng)常碰到橫屏豎屏的問題,那么我們應(yīng)該如何去判斷或者針對(duì)橫屏、豎屏來寫不同的代碼呢。

成都服務(wù)器托管,創(chuàng)新互聯(lián)提供包括服務(wù)器租用、成都服務(wù)器托管、帶寬租用、云主機(jī)、機(jī)柜租用、主機(jī)租用托管、CDN網(wǎng)站加速、域名與空間等業(yè)務(wù)的一體化完整服務(wù)。電話咨詢:13518219792

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

<meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>

針對(duì)上述viewport標(biāo)簽有如下說明

1)、content中的width指的是虛擬窗口的寬度。

2)、user-scalable=no就一定可以保證頁面不可以縮放嗎?NO,有些瀏覽器不吃這一套,還有一招就是minimum-scale=1.0, maximum-scale=1.0 最大與最小縮放比例都設(shè)為1.0就可以了。

3)、initial-scale=1.0 初始縮放比例受user-scalable控制嗎?不一定,有些瀏覽器會(huì)將user-scalable理解為用戶手動(dòng)縮放,如果user-scalable=no,initial-scale將無法生效。

4)、手機(jī)頁面可以觸摸移動(dòng),但是如果有需要禁止此操作,就是頁面寬度等于屏幕寬度是頁面正好適應(yīng)屏幕才可以保證頁面不能移動(dòng)。

5)、如果頁面是經(jīng)過縮小適應(yīng)屏幕寬度的,會(huì)出現(xiàn)一個(gè)問題,當(dāng)文本框被激活(獲取焦點(diǎn))時(shí),頁面會(huì)放大至原來尺寸。

一:CSS判斷橫屏豎屏

寫在同一個(gè)CSS中

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

分開寫在2個(gè)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判斷橫屏豎屏

//判斷手機(jī)橫豎屏狀態(tài):
window.addEventListener("onorientationchange" in window ? "orientationchange" : "resize", function() {
    if (window.orientation === 180 || window.orientation === 0) { 
      alert('豎屏狀態(tài)!');
    } 
    if (window.orientation === 90 || window.orientation === -90 ){ 
      alert('橫屏狀態(tài)!');
    } 
  }, false); 
//移動(dòng)端的瀏覽器一般都支持window.orientation這個(gè)參數(shù),通過這個(gè)參數(shù)可以判斷出手機(jī)是處在橫屏還是豎屏狀態(tài)。

最近項(xiàng)目有電子合同方面的開發(fā),需要電子簽字,(用的jsignature插件,如果有空以后單獨(dú)寫個(gè)使用心得)。在手機(jī)小屏幕上簽字,全屏橫屏才是最好的體驗(yàn)。用戶豎屏打開頁面時(shí)要去簽字,提示用戶把手機(jī)橫過來,這樣體驗(yàn)太low了,程序員要考慮能用技術(shù)解決的就不要去勞煩用戶(免得用戶煩了回頭打電話咬你)。

先來幾個(gè)檢測(cè)屏幕方向的方法:

//判斷屏幕方向
if(window.orientation==90||window.orientation==-90){
  alert("橫屏狀態(tài)!")
}
//監(jiān)聽屏幕方向
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) { }豎屏 

進(jìn)入網(wǎng)頁檢測(cè)是否橫屏狀態(tài),不是就給canvas加樣式:

transform: rotate(90deg);

最初想的是把jsignature的canvas畫布用css3transform橫過來就可以了,誰想到,畫布橫是過來了,touch相關(guān)的手勢(shì)還是豎的(簽字啊,筆畫不跟手怎么簽)。如果是普通項(xiàng)目?jī)H僅是顯示的話,上面的方法已經(jīng)夠用了。

還好這個(gè)項(xiàng)目是網(wǎng)頁內(nèi)嵌app中,app有方法強(qiáng)制網(wǎng)頁橫屏,改了改頁面,交上去了。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)創(chuàng)新互聯(lián)的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

網(wǎng)站標(biāo)題:移動(dòng)端使用CSS或JS判斷橫屏和豎屏的講解
網(wǎng)站URL:http://jinyejixie.com/article46/gpsihg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、商城網(wǎng)站、App開發(fā)、響應(yīng)式網(wǎng)站、微信小程序、企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)
阿拉善右旗| 朝阳市| 白山市| 万年县| 孝义市| 同德县| 新密市| 方正县| 平度市| 铜鼓县| 隆化县| 张家界市| 张家界市| 米泉市| 建昌县| 普宁市| 五原县| 普陀区| 开化县| 安远县| 三门峡市| 黔南| 沽源县| 依兰县| 怀柔区| 收藏| 蒙自县| 孙吴县| 连州市| 孝昌县| 稻城县| 涞水县| 繁峙县| 尖扎县| 铜梁县| 青田县| 历史| 融水| 乐至县| 桦南县| 临武县|