精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

移動應用中全屏模式要點研究

譯文
移動開發
移動應用中的用戶體驗是最重要的,在本文中,將給讀者講解在日新月異的對移動應用支持的相當優秀的瀏覽器中,如何實現豐富多彩的全屏效果。本文適合的閱讀對象為有一定移動HTML 5開發基礎的讀者。

移動應用中的用戶體驗是最重要的,在本文中,將給讀者講解在日新月異的對移動應用支持的相當優秀的瀏覽器中,如何實現豐富多彩的全屏效果。本文適合的閱讀對象為有一定移動HTML 5開發基礎的讀者。

目前,我們已經能夠實現多姿多彩的網站或網頁的全屏效果,并且已經有不少實現的方法。全屏效果的移動應用,給用戶更寬廣的界面視野,因為手機的屏幕一般都比較小,可以讓用戶十分方便地操作,特別在一些移動游戲中尤其如此。幸好現在各大移動瀏覽器都支持“安裝式”的web應用,其中大多用到了全屏效果。

下面我們來看下實現web應用全屏效果有什么方法:

隱藏地址欄

讀者能想到最簡單的方法,就是自動隱藏瀏覽器的地址欄,可以使用一段簡單的Javascript代碼:

  1. <script type="text/javascript"
  2.     addEventListener("load", function() { setTimeout(hideURLbar, 0); }, false); 
  3.     function hideURLbar(){ 
  4.               window.scrollTo(0,1); 
  5.     } 
  6. script> 

這個方法無疑是最簡單的,在頁面打開的時候來瀏覽器的地址欄被自動隱藏了。但可惜的是,這樣的方法并不是最標準的并且瀏覽器對其支持不大好。你可能不得不處理一些奇怪的問題和現象。比如當用戶在頁面需要來回導航的時候,偶然地址欄還是會在頁面中恢復其位置。所以有的時候,用戶對此感到惱怒。而且要注意只有當頁面內容的高度超過屏幕瀏覽器的高度的時候,才會自動隱藏地址欄,否則不會自動隱藏,如果內容比較少的時候,可以在滾動之前程序動態設置一下body的高度,增加如下代碼

  1.      . if(document.documentElement.scrollHeight <= document.documentElement.clientHeight) { 
  2.     bodyTag = document.getElementsByTagName('body')[0]; 
  3.     bodyTag.style.height = document.documentElement.clientWidth / screen.width * screen.height + 'px'
  4. •    

利用移動瀏覽器的全屏API特性

現在的移動瀏覽器中,大多支持全屏API,而且全屏API是HTML 5規范中的標準。但遺憾的是iOS不支持全屏API(IE 11才開始支持全屏API)。我們下面討論的是支持全屏API的Chrome for Android和FireFox。

在使用全屏API中,重點關注以下幾個API:

•     element.requestFullscreen()

 以全屏方式顯示元素(目前Chrome和Firefox都支持)

•    document.cancelFullscreen()

取消全屏模式(目前Chrome和Firefox都支持)

•    document.fullscreenElement

如果當前任何一個元素以全屏模式顯示,則返回true

要注意當應用在全屏模式下的時候,用戶不能使用原來瀏覽器的控件了,這將稍微改變用戶的體驗。他們不能使用前進和導航按鈕;他們唯一能用的按鈕就是刷新按鈕。因此開發者必須應對這種情況。可以在全屏模式下,使用CSS選擇器去改變樣式。下面看下如何用代碼實現全屏模式:

  1. <button id="goFS">Go fullscreen<button> 
  2. <script> 
  3.    var goFS = document.getElementById("goFS"); 
  4.    goFS.addEventListener("click", function() { 
  5.       document.body.requestFullScreen(); 
  6.    }, false); 
  7. </script> 

以上是全屏模式最簡單的用法了。Mozilla發布了一個很有用的腳本能很好地實現全屏模式,摘要相關代碼如下:

  1.  function toggleFullScreen() { 
  2. var doc = window.document; 
  3. var docEl = doc.documentElement; 
  4.  
  5. var requestFullScreen = docEl.requestFullscreen || docEl.mozRequestFullScreen || docEl.webkitRequestFullScreen; 
  6. var cancelFullScreen = doc.exitFullscreen || doc.mozCancelFullScreen || doc.webkitExitFullscreen; 
  7.  
  8. if(!doc.fullscreenElement && !doc.mozFullScreenElement && !doc.webkitFullscreenElement) { 
  9.   requestFullScreen.call(docEl); 
  10. else { 
  11.   cancelFullScreen.call(doc); 

這段代碼的核心其實就是加上判斷不同的瀏覽器的類型而已。當然,如果開發者覺得使用起來依然不方便,可以嘗試使用 Screenfull.js這個小巧的和全屏相關的Javascript類庫,也是挺好用的。

如何啟動全屏API的應用

要在啟動一個頁面的時候,自動進入全屏模式是不可能的。其原因可能在于瀏覽器廠商可能也意識到不經過用戶允許而自動進入全屏模式,是十分不厚道的事情。因此,用戶如果要進入全屏模式,都必須由用戶主動確認。目前各主流的移動瀏覽器,都支持使用標簽和腳本等,實現啟動全屏API,分別介紹下:

iOS

在iPhone中,用戶可以將Web應用安裝到home主屏中去,并且讓它們以全屏方式啟動,代碼為;

  1. <meta name="apple-mobile-web-app-capable" content="yes"

如果content設置為yes,則表示啟動全屏模式,否則默認為否。

Chrome for Android

Chrome團隊最近實現了和iOS類似的機制,當用戶增加應用到主屏時,實現全屏模式,代碼為:

  1. <meta name="mobile-web-app-capable" content="yes"

Firefox OS

=在Firefox OS手機系統中,實現的機制稍微復雜。Firefox OS需要開發者編寫部署的文件,然后Firefox OS在應用部署的時候會進行自動解析并安裝為全屏應用,代碼片段:

  1.   "name""My App"
  2.   "description""My elevator pitch goes here"
  3.   "launch_path""/"
  4.   "icons": { 
  5.     "128""/img/icon-128.png" 
  6.   }, 
  7.   "fullscreen"true 

詳細的用法參考:https://developer.mozilla.org/en-US/Apps/Developing/Manifest#fullscreen

全屏API使用的技巧

如果想將body部分進行全屏化,則在基于Webkit或者blink引擎的瀏覽器中,會發現body部分會縮小到只能包含內容的區域,周圍會有黑色的縫隙(但Mozilla的Gecko不會有這個問題)。如下圖所示:

可以使用如下的方法去進行修復:

  1. document.documentElement.requestFullScreen(); 

其效果如下圖:

如何讓視頻變為全屏

下面講解如何將視頻進行全屏顯示,代碼如下:

  1. <video id=videoElement></video> 
  2. <button id="goFS">Go Fullscreen</button> 
  3. <script> 
  4.    var goFS = document.getElementById("goFS"); 
  5.    goFS.addEventListener("click", function() { 
  6.       var videoElement = document.getElementById("videoElement"); 
  7.       videoElement.requestFullScreen(); 
  8.    }, false); 
  9. </script> 

上面的方法并不是***的,***的方法是將視頻控件放在某個div中,并且為視頻控件設置屬性,這樣用戶才能很方便地使用視頻控件,代碼如下:

  1.  <div id="container"
  2.   <video><video> 
  3.   <div> 
  4.     <button>Play<button> 
  5.     <button>Stop<button> 
  6.     <button id="goFS">Go fullscreen<button> 
  7.   <div> 
  8. <div> 
  9. <script> 
  10.    var goFS = document.getElementById("goFS"); 
  11.    goFS.addEventListener("click", function() { 
  12.       var container = document.getElementById("container"); 
  13.       container.requestFullScreen(); 
  14.    }, false); 
  15. <script> 

甚至我們可以加點CSS控制樣式,如:

  1.  <style> 
  2. #goFS:full-screen #goFS { 
  3.   display: none; 
  4. #goFS:-webkit-full-screen #goFS { 
  5.   display: none; 
  6. #goFS:-moz-full-screen #goFS { 
  7.   display: none; 
  8. <style> 

全屏應用的設計注意事項

要注意的是,在iOS或者FireFox OS中的設備中是沒有物理的后退或刷新功能鍵的,因此必須確保用戶能在全屏模式下不會影響用戶的體驗,其中可以通過全屏相關的API去判斷用戶是否處于全屏模式中。

在iOS中的判斷方法如下:

  1.   if(window.navigator.standalone == true) { 
  2.         //應用已經安裝而且為全屏模式 

但在Chrome for Android中,document.fullscreenElement會返回null并且也不象Ios那樣能有window.navigator.standalone屬性,則可以使用如下的CSS代碼去顯示只有在全屏模式下才能顯示的元素。

  1.  selector:-webkit-full-screen { 
  2.   display: block; // 只在全屏模式下顯示 
  1. selector { 
  2.   display: none; // 不在全屏模式下隱藏元素 

而在Firefox OS中,用法基本是相同的,只是部分CSS代碼的拼寫有點不同,即:

  1. selector:-moz-full-screen { 
  2.   display: block; // hides the element when not in fullscreen mode 
  3.  
  4. selector { 
  5.   display: none; // hides the element when not in fullscreen mode 

讓用戶在全屏模式下操作要注意的

盡管全屏模式有這樣那樣的好處,但事實上各瀏覽器廠商也想了很多辦法能讓用戶隨時跳出全屏應用,因此是不可能實現同時在多個頁面中使用全屏的,因為:

1) 一旦使用window.location去改變url連接則會退出全屏模式

2) 用戶一旦點了外部鏈接,則會退出全屏模式

3) 使用navigator.pushState也會退出全屏模式

那么你可以考慮以下的兩個方法盡可能實現全屏模式:

1) 使用可安裝的web app去實現全屏效果

2) 盡可能使用#錨點的語法去在頁面間導航

讓用戶有選擇全屏方式的權利

千萬不要過分濫用全屏方式,而且盡量避免用戶一開始進入應用就馬上切換到全屏,模式。每當需要用到全屏方式前,應該要提醒用戶。當然瀏覽器也會

提醒用戶,比如在Firefox OS中,提醒的方式如下圖:

適當提醒用戶安裝你的應用

如果想通過安裝app的機制去提供全屏模式體驗,則必須考慮以下幾點:

•    在頁頭或頁腳使用足夠的信息提醒用戶可以安裝這個app

•    如果用戶取消了安裝提示,則不要再顯示,否則用戶會感到厭倦

•    用戶在***次訪問的時候,除非是特別喜愛你的應用提供的服務,否則是不會馬上安裝應用的。應該考慮在用戶使用足夠長的時間后才提示用戶是否安裝應用

•    如果發現你的用戶經常有規律地訪問你的應用,但并不安裝,則很大可能他們以后也不大愿意安裝了,這個時候不要老給出提示信息以打擾用戶。

小結

本文小結了目前主流移動瀏覽器中對全屏模式的主要支持情況,介紹了如何用多種方法支持移動應用的全屏模式,以及其中HTML 5中全屏模式主要API的使用。在移動應用中使用全屏API有利有弊,利在于可以讓用戶在使用移動應用的時候,有更足夠的視野空間操作,但弊端在于如果不給予用戶足夠提示的話,則有可能讓用戶在操作上感到迷茫,因此開發者必須十分留意。

責任編輯:張葉青 來源: 51CTO
相關推薦

2015-04-21 13:50:53

電信運營商移動互聯網應用開發

2012-01-03 19:09:42

移動應用

2014-08-21 13:43:26

移動互聯網租車應用研究報告

2013-01-06 16:03:18

Facebook移動廣告

2009-07-16 16:09:51

Swing全屏幕模式

2016-08-02 14:29:49

移動支付移動通訊移動金融

2010-07-29 14:58:49

Flex全屏模式

2011-05-02 11:32:24

Android應用商店

2011-03-23 08:34:43

設計應用

2011-04-21 09:46:41

設計模式

2011-06-02 18:02:50

iPhone MVC

2013-09-04 11:26:41

移動應用界面設計

2012-03-07 10:07:19

云計算云應用

2011-07-11 16:25:25

控制臺

2009-12-30 14:22:12

Silverlight

2012-03-09 14:19:12

企業移動應

2011-12-15 21:24:46

應用

2023-12-14 12:42:42

2015-05-21 18:14:44

2011-05-20 10:11:19

點贊
收藏

51CTO技術棧公眾號

国产免费www| 精品剧情v国产在线观看在线| 欧美日韩一区精品| 成人在线视频网址| av在线免费播放网址| 91美女精品| 91精品国产乱码久久久久久久| 秋霞午夜av一区二区三区| 日韩欧美一区二区在线视频| 日韩精品久久一区| 无码aⅴ精品一区二区三区| 99精品中文字幕在线不卡| 国产精品毛片大码女人| 国产suv精品一区二区| 蜜臀av免费观看| 日韩精品福利| 亚洲中午字幕| 日韩精品极品在线观看| 日韩精品另类天天更新| av网站在线免费看| 亚洲天堂免费| 日韩女同互慰一区二区| 免费国产成人av| 欧美18xxxxx| 日韩中文字幕av电影| 亚洲欧美中文另类| 北条麻妃av高潮尖叫在线观看| 日韩专区第一页| 在线亚洲国产精品网站| 亚洲精品国产suv| 国产中文字幕二区| 一级黄色大毛片| 水蜜桃久久夜色精品一区| 欧美日韩综合在线免费观看| 国产不卡一区二区视频| 污视频网站在线播放| 一区二区三区高清视频在线观看| 欧美精品一区二区三区蜜臀| 欧美在线观看视频免费| 亚洲精品成人区在线观看| 好看的日韩av电影| 欧美日韩大陆一区二区| 日韩不卡一二区| 丰满人妻一区二区三区四区53| 日韩免费特黄一二三区| 欧美另类变人与禽xxxxx| 97超碰免费观看| 中文字幕在线播放| 国产大陆a不卡| 91po在线观看91精品国产性色 | 亚洲成人免费| 爽爽爽爽爽爽爽成人免费观看| 奇米影视亚洲色图| 成人在线播放免费观看| 福利一区在线观看| 2019中文字幕免费视频| 免费黄色在线网址| 国产精品一区二区日韩| 精品在线你懂的| 自拍偷拍亚洲在线| 稀缺小u女呦精品呦| 一级毛片久久久| 亚洲人精品午夜| 国产日韩欧美综合精品| a片在线免费观看| 牛牛国产精品| 亚洲无限av看| 在线观看亚洲免费视频| 亚洲成人一区在线观看| 亚洲激情欧美激情| 日本不卡高清视频一区| 亚洲在线视频播放| 一区二区高清| 日本欧美精品在线| 一级黄色大片免费| 中文字幕一区二区三区在线视频| 精品在线小视频| 宇都宫紫苑在线播放| 免费a级在线播放| 久久成人av少妇免费| 国产又爽又黄的激情精品视频| 91免费公开视频| 最新国产一区| 精品裸体舞一区二区三区| 中文字幕99页| 99精品在线免费观看| 色悠久久久久综合欧美99| 大陆极品少妇内射aaaaaa| wwwww亚洲| 亚洲免费观看高清在线观看| 日本在线观看一区二区| 日本在线人成| 亚洲国产经典视频| 欧美日韩一区在线视频| 污污视频在线免费看| 久久久久久久久久久电影| 国产综合18久久久久久| 欧洲亚洲在线| 亚洲男人的天堂网| 免费观看日韩毛片| 热三久草你在线| 午夜国产精品一区| 日韩资源av在线| 国产91免费看| 日本一区二区成人在线| 欧美一区二区三区综合| 国精产品一区二区三区有限公司| 国产精品第四页| 免费国产一区| 国产精品久久久久久久免费| 激情综合视频| 欧美大片免费观看| 久久久久久久久久久久久久久| 另类一区二区| 欧美日韩精品综合在线| a级一a一级在线观看| 北条麻妃一区二区三区在线观看| 日韩一区二区三区三四区视频在线观看| 欧美亚洲色图视频| 欧洲性视频在线播放| 玉米视频成人免费看| 亚洲 中文字幕 日韩 无码| 色成人免费网站| 亚洲电影免费观看高清完整版在线| 男女污污的视频| 亚洲电影有码| 欧美裸体bbwbbwbbw| 国产人妻一区二区| 波多野结衣在线观看一区二区三区 | 久久人人妻人人人人妻性色av| 性欧美1819sex性高清| 色综合天天综合狠狠| 99riav国产精品视频| 久久精品青草| 国产日韩欧美电影在线观看| 能在线看的av| 韩曰欧美视频免费观看| 亚洲成熟丰满熟妇高潮xxxxx| 丝袜中文在线| 红桃视频成人在线观看| 116极品美女午夜一级| 国产精品1luya在线播放| 亚洲精品www久久久久久广东| 人妻体内射精一区二区| 日韩精品免费一区二区三区| 日韩美女在线看| 手机在线精品视频| 黄色一区二区在线| 蜜桃传媒一区二区亚洲av| 凹凸成人精品亚洲精品密奴| 日韩美女中文字幕| а天堂8中文最新版在线官网| 99re66热这里只有精品3直播 | 日韩色淫视频| 亚洲视频视频在线| 久草视频在线免费| 国产一区二区成人久久免费影院| 午夜免费日韩视频| 日韩免费av网站| 韩国精品一区二区| 久久久一本精品99久久精品| 女人18毛片水真多18精品| www一区二区| 欧美美女黄色网| av超碰免费在线| 日韩欧美在线播放| 国产xxxxhd| 亚洲视频碰碰| 六十路精品视频| 91伊人久久| 日韩成人在线观看| 亚洲欧美综合7777色婷婷| 理论电影国产精品| 久久亚洲综合网| 中文字幕免费高清电视剧网站在线观看| 一本色道久久综合亚洲精品按摩| 少妇献身老头系列| 色呦哟—国产精品| 91欧美日韩一区| 最新97超碰在线| 欧美一区二区免费视频| 黄色免费一级视频| 午夜亚洲视频| 亚洲一区二区三区精品动漫| 大胆人体一区| 精品国模在线视频| 懂色av蜜臀av粉嫩av喷吹| 亚洲欧洲成人av每日更新| 久久精品网站视频| 忘忧草精品久久久久久久高清| 欧美成人在线网站| 中文字幕一区二区三区四区免费看 | 色阁综合伊人av| 亚洲图片欧美日韩| 亚洲欧美成aⅴ人在线观看| 精品1卡二卡三卡四卡老狼| 老**午夜毛片一区二区三区| 成人在线视频电影| 日韩三区在线| 色综合久久精品亚洲国产| 国产精品一品二区三区的使用体验| 久久久久亚洲综合| 欧美污在线观看| 久久久国产精品一区二区中文| 国产拍精品一二三| 成人av影院在线观看| 色一区av在线| 国产v在线观看| 日韩欧美国产中文字幕| 久久久国产精品人人片| 国产 欧美在线| 亚洲色图久久久| 亚洲伦伦在线| 欧美高清性xxxxhd| 日韩精品影片| 高清一区二区三区四区五区| 波多野结衣一二区| 亚洲国产乱码最新视频| 第四色在线视频| 一区二区日韩免费看| 久久久久久久久久久一区 | 亚洲av无码片一区二区三区| 一区二区三区蜜桃网| 久久综合桃花网| 老司机一区二区| 欧美日韩怡红院| 亚洲免费网址| 青青草视频在线免费播放| 午夜久久黄色| 日本xxx免费| 亚洲二区三区不卡| 一区不卡视频| 久久在线视频免费观看| 日韩在线电影一区| 玖玖精品一区| 久久久爽爽爽美女图片| 日韩精品系列| 欧美美女一区二区在线观看| 无码视频在线观看| 欧美日韩激情美女| aaa人片在线| 亚洲国产精品ⅴa在线观看| 一级黄色高清视频| 欧美日韩一二三四| 97视频免费在线看| 1769在线观看| 中文字幕在线看视频国产欧美| 亚洲伦理在线观看| 精品久久一二三区| 天天操天天干天天爱| 亚洲国产精品久久久久久| 中文字幕+乱码+中文字幕明步 | 国产经典久久久| 欧美黄色大片网站| 日韩伦理在线免费观看| 一本久道久久综合狠狠爱| 亚洲午夜在线观看| 999国产精品| 天堂а√在线中文在线| 国产精品v日韩精品v欧美精品网站 | 专区另类欧美日韩| 91久久免费视频| 国产欧美日韩视频一区二区| 国产精品探花在线播放| 国产一区不卡视频| 中国特级黄色片| 99久久精品免费| 波多野吉衣在线视频| 成人午夜视频在线观看| 黄色三级视频在线| 国内外成人在线| 91蝌蚪视频在线观看| 麻豆中文一区二区| 在线成人精品视频| 美腿丝袜一区二区三区| 91九色在线观看视频| 欧美国产日本| 欧美日韩一道本| 日韩高清一级片| 天天摸天天舔天天操| 丝袜诱惑亚洲看片| 日韩av一卡二卡三卡| 国产sm精品调教视频网站| 精品夜夜澡人妻无码av| 成人午夜伦理影院| 日韩一区二区a片免费观看| 国产精品久久久久久久久免费樱桃| 一区二区三区免费在线观看视频| 高清国产一区二区| 一道本在线观看| 一区二区三区四区在线| 亚洲熟女综合色一区二区三区| 国产欧美一区二区在线| 一区二区三区影视| 最新久久zyz资源站| 久久草视频在线| 亚洲一区二区欧美激情| asian性开放少妇pics| 亚洲欧洲无码一区二区三区| 日韩和一区二区| 亚洲成av人片一区二区梦乃| 欧美brazzers| 日本道在线观看一区二区| 波多野结衣视频网站| 欧美日韩美女视频| 一区二区精品视频在线观看| 亚洲国产中文字幕久久网 | h片视频在线观看| 国产精品免费视频久久久| free欧美| 国产传媒一区| 香港欧美日韩三级黄色一级电影网站| 一本色道久久综合亚洲二区三区| 91久久国产| 99免费视频观看| www.色精品| 亚洲中文字幕一区| 久久久精品一品道一区| 中文字幕第28页| 岛国av在线不卡| 国产aⅴ一区二区三区| 中文字幕亚洲色图| 成人免费看视频网站| 国产精品美女久久久免费| 久久精品97| 精品日韩欧美| 欧美精品一区二区久久| 亚洲一区三区在线观看| 国产精品日本| 污视频免费在线观看网站| 91久色porny| 黄色片视频网站| 日韩女优视频免费观看| 制服丝袜中文字幕在线| 成人黄色在线观看| 激情中国色综合| 奇米视频888战线精品播放| 天天久久综合| 成人不卡免费视频| 国产精品另类一区| 国产亚洲欧美久久久久| 欧美一区2区视频在线观看| 米奇精品一区二区三区| 成人国产精品av| 国产精品久久久久无码av| 亚洲激情在线看| 99精品热视频| 精品在线观看一区| 欧美丰满嫩嫩电影| 五月天久久久久久| 美乳少妇欧美精品| 免费观看亚洲视频大全| 日韩亚洲一区在线播放| 视频一区欧美日韩| 欧美一区二区三区粗大| 欧美日韩一区在线观看| 久久久久久久久免费视频| 97在线免费观看| 一区二区三区视频免费观看| 欧美极品jizzhd欧美| 国产一区二区三区成人欧美日韩在线观看| 天天干天天av| 自拍偷拍国产精品| 无码日韩精品一区二区| 最新国产精品亚洲| 日韩欧美另类中文字幕| 日韩一区二区三区高清| 久久99精品国产.久久久久久| av在线网站观看| 日本国产一区二区| 欧美成人片在线| 国产狼人综合免费视频| 欧美1区2区3区4区| 超级碰在线观看| 成人国产视频在线观看| 黄色录像a级片| 在线观看视频欧美| 四虎影院在线播放| 欧美激情免费看| 妖精一区二区三区精品视频| 国精产品一区一区三区视频| 久久久久国产精品麻豆ai换脸| 西西44rtwww国产精品| 亚洲国产另类 国产精品国产免费| av大片在线| 欧美日韩另类丝袜其他| 精品一区二区在线视频| 欧美成人aaaaⅴ片在线看| 在线视频亚洲欧美| 99亚洲乱人伦aⅴ精品| 国产视频一区二区三区在线播放 | 日韩亚洲欧美中文字幕| 欧美成人猛片aaaaaaa| 羞羞的视频在线观看| 亚洲一区二区三区久久| 日韩亚洲一区在线| 国产日韩视频一区| 69堂国产成人免费视频| 色多多视频在线观看| 国产日产欧美精品|