成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

微信小程序適配iPhone X總結(jié)

移動開發(fā)
本文主要介紹我們的知識小集小程序在適配 iPhone X 屏幕時遇到的一些問題以及總結(jié),希望對你的小程序開發(fā)能有所幫助。

本文主要介紹我們的知識小集小程序在適配 iPhone X 屏幕時遇到的一些問題以及總結(jié),希望對你的小程序開發(fā)能有所幫助。

iPhone X 屏幕數(shù)據(jù)

在去年 9 月份 iPhone X 正式發(fā)布后,引發(fā)了一波 iOS App 適配 iPhone X 的熱潮和技術(shù)文章。我們這里先簡單總結(jié)一下 iPhone X 屏幕的基礎(chǔ)數(shù)據(jù),方便后續(xù)在小程序開發(fā)中進行適配。

  • 屏幕尺寸:5.8 英寸(對角線)
  • 屏幕物理分辨率:1125px × 2436px,458 ppi
  • 實際開發(fā)適配尺寸:375pt × 812pt,@3x

此外,由于在 iPhone X 屏幕頂部狀態(tài)欄區(qū)域有“齊劉海”,以及在屏幕底部增加了“操作條”,如下圖所示,因此,我們在開發(fā)中需要注意安全區(qū)域的問題。 

[[238031]]

根據(jù)蘋果官方的文檔,iPhone X 頂部狀態(tài)欄的適配安全區(qū)域的高度為 44pt,底部操作條區(qū)域的高度為 34pt。另外,在 iPhone X 中,一些系統(tǒng) Bar 的默認高度相比于之前的設(shè)備也發(fā)生了變化,如下表所示。 

所以在 iOS App 開發(fā)中,如果我們使用系統(tǒng)默認的 UINavigationController 和 UITabBarController 時,則無需額外的適配工作,iOS 系統(tǒng)會自動適配好相關(guān) Bar 的安全區(qū)域問題。如果我們使用了自定義的導(dǎo)航欄和標簽欄,則需要注意根據(jù)設(shè)備類型區(qū)分設(shè)置這些 Bar 的不同高度。

小程序的尺寸單位

為了解決不同屏幕尺寸的適配問題,小程序自己定了一個尺寸單位:rpx(responsive pixel),它可以根據(jù)屏幕寬度進行自適應(yīng)。小程序中規(guī)定,所有設(shè)備的屏幕寬度都為 750rpx,根據(jù)設(shè)備屏幕實際寬度的不同,1rpx 所代表的實際像素值也不一樣。

根據(jù)微信開發(fā)文檔,在 4.7 英寸的 iPhone 設(shè)備上(iPhone 6/7/8),屏幕寬度為 375px(此處應(yīng)該理解為 375 point),共有 750 個物理像素,則 750rpx = 375px = 750 物理像素,1rpx = 0.5px = 1物理像素。 

小程序中如何判斷設(shè)備為 iPhone X

上面我們簡要介紹了 iPhone X 的屏幕數(shù)據(jù)和小程序中的尺寸單位作為鋪墊,現(xiàn)在終于要切入正題了,要在小程序中適配 iPhone X 屏幕,首先我們需要知道如何判斷設(shè)備類型。

微信的小程序 API 中提供了一個 wx.getSystemInfo(OBJECT) 方法用于獲取用戶手機的系統(tǒng)信息和設(shè)備信息,包含如下數(shù)據(jù): 

上述每個字段的含義詳見文檔,我們不再一一贅述。

因此,我們可以根據(jù)該方法返回的手機型號字段 model 是否包含 iPhone X 字符串來判斷設(shè)備是否為 iPhone X,也可以根據(jù) screenHeight 的高度是否等于 812 來判斷。

NOTE: 這里有一個小坑需要注意,在微信開發(fā)者工具中的模擬器,如果選擇為 iPhone X,此時獲取到的 model 值為 iPhone X,導(dǎo)致我以為真機也是這個值,于是直接用 if (model == 'iPhone X') 來判斷,但其實真機下 model 的值為這種格式: iPhone X (GSM+CDMA),因此我們需要用字符串檢索匹配進行判斷。

綜上,我們可以在 app.js 的 globalData 中添加一個字段 isIPX 用于標識當前設(shè)備是否為 iPhone X,然后在小程序啟動時 onLaunch 中調(diào)用 wx.getSystemInfo(OBJECT) 方法并在其 success 回調(diào)中讀取 model 字段進行分析,代碼大致如下:

  1. App({ 
  2.   // 全局數(shù)據(jù) 
  3.   globalData: { 
  4.     // 其他數(shù)據(jù)定義 ... 
  5.      
  6.     isIPX: false, // 當前設(shè)備是否為 iPhone X 
  7.   }, 
  8.    
  9.   // 小程序啟動入口 
  10.   onLaunch: function (options) { 
  11.     // 其他啟動代碼... 
  12.      
  13.     // 判斷設(shè)備是否為 iPhone X 
  14.     this.checkIsIPhoneX() 
  15.   }, 
  16.    
  17.   checkIsIPhoneX: function() { 
  18.     const self = this 
  19.     wx.getSystemInfo({ 
  20.       success: function (res) { 
  21.         // 根據(jù) model 進行判斷 
  22.         if (res.model.search('iPhone X') != -1) { 
  23.           self.globalData.isIPX = true 
  24.         } 
  25.         // 或者根據(jù) screenHeight 進行判斷 
  26.         // if (res.screenHeight == 812) { 
  27.         //   self.globalData.isIPX = true 
  28.         // } 
  29.       } 
  30.     }) 
  31.   }, 

如果需要小程序啟動時立即獲取設(shè)備相關(guān)信息,也可以調(diào) wx.getSystemInfoSync() 方法,它會同步獲取數(shù)據(jù)并立即返回。

頁面適配實戰(zhàn)

在小程序頁面開發(fā)中,涉及到需要適配 iPhone X 的地方主要有:導(dǎo)航欄(NavigationBar),標簽欄(TabBar)以及頁面底部的吸底按鈕。

導(dǎo)航欄和標簽欄適配

如果我們使用微信小程序官方組件進行開發(fā),沒有進行自定義,在 app.json 文件中設(shè)置 tabBar 頁面,且 window 的 navigationStyle 值為 default,那么我們無需在 iPhone X 中對導(dǎo)航欄和標簽欄進行適配,微信會自動幫我們適配好,如下圖為知識小集小程序的首頁: 

但是我們?nèi)绻亲远x導(dǎo)航欄(在 app.json 文件中設(shè)置 window 的 navigationStyle 為 custom,此時只保留右上角膠囊狀的按鈕,需要開發(fā)者自己畫導(dǎo)航欄樣式)和標簽欄,則我們需要在每個頁面中判斷設(shè)備類型,并針對 iPhone X 屏幕在安全區(qū)域內(nèi)進行布局,并修改相關(guān) Bar 的高度值(見上述表格)。

以自定義導(dǎo)航欄適配為例,步驟如下:

(1)在每個頁面的 page.js 中先讀取 app.js 中的 isIPX 值,如下:

  1. const app = getApp() 
  2.  
  3. Page({ 
  4.   data: { 
  5.     // 頁面其他數(shù)據(jù)... 
  6.      
  7.     isIPX: app.globalData.isIPX, 
  8.   }, 
  9.    
  10.   // 其他代碼 

(2)然后在 page.wxss 樣式文件中對某一個視圖 View 分別為普通屏幕和 iPhone X 屏幕寫兩種樣式,如下:

  1. .navi-bar-view { 
  2.   height: 64px; 
  3.   /* 其他樣式值 */ 
  4. .navi-bar-view-IPX { 
  5.   height: 88px; 
  6.   /* 其他樣式值 */ 

(3)***在 page.wxml 頁面結(jié)構(gòu)布局中根據(jù) isIPX 的值給 View 設(shè)置不同的 class 樣式,如下:

  1. <view class="{{isIPX ? 'navi-bar-view-IPX' : 'navi-bar-view'}}"
  2. </view

此外,對于自定義導(dǎo)航欄和標簽欄,我建議還是要遵循 iPhone UI 的設(shè)計規(guī)范,樣式可以參考蘋果官方的渲染圖: 

吸底按鈕適配

在小程序頁面中,吸底按鈕是很常見的一種設(shè)計,我們一般會把一些重要的按鈕放在頁面底部懸浮不動,例如我們知識小集小程序的“小集詳情頁”底部的“收藏”和“轉(zhuǎn)發(fā)”按鈕: 

在 iPhone X 中我們需要把吸底按鈕往上偏移 34 像素,可通過在 CSS 樣式中設(shè)置 padding-bottom 為 34px 實現(xiàn),參考代碼如下:

  1. .feed-bottom-view { 
  2.   width: 100%; 
  3.   height: 48px; /* 吸底按鈕的高度 */ 
  4.   bottom: 0; 
  5.   opacity: 0.95; 
  6.   position: fixed; 
  7.   border-top-style: solid; 
  8.   border-top-width: 0.5px; /* 分割線的高度 */ 
  9.   border-color: lightgrey; 
  10.   background-color: #F8F8F8; 
  11. .feed-bottom-view-IPX { 
  12.   /* iPhone X 內(nèi)容往上偏移 34px */ 
  13.   padding-bottom: 34px; 
  14.  
  15. <view class="{{isIPX ? 'feed-bottom-view feed-bottom-view-IPX' : 'feed-bottom-view'}}"
  16. <!-- 底部吸底按區(qū)域 --> 
  17. </view

備注:如前面所述,對于不同設(shè)備寬度,1rpx 所代表的實際像素值也不一樣,而在不同尺寸的 iPhone 設(shè)備(3.5/4.0/4.7/5.5 英寸)中,雖然它們的寬度不同,但其導(dǎo)航欄+狀態(tài)欄的高度都為 64pt(iPhone X 為 88pt),標簽欄 TabBar 的高度都為 49pt(iPhone X 為 83pt)。所以在小程序開發(fā)中,當我們需要自定義導(dǎo)航欄、標簽欄,或者適配 iPhone X 頂部和底部安全區(qū)域時,我建議此處的單位直接使用 px(在小程序中對應(yīng) iOS 開發(fā)中的點 pt)而不使用 rpx(當然頁面的其他元素的尺寸描述還是推薦使用 rpx),以確保最終渲染顯示的高度與 iOS 系統(tǒng)默認的一致。

總結(jié)

本文簡要介紹了在小程序開發(fā)中如何適配 iPhone X 屏幕,更多細節(jié)請查閱我們在 GitHub 上開源的知識小集小程序的代碼:awesome-tips-wx-app

責任編輯:未麗燕 來源: Zubin's Blog
相關(guān)推薦

2018-03-30 15:46:17

直播微信小程序

2017-05-08 15:03:07

微信小程序開發(fā)實戰(zhàn)

2016-10-20 21:02:12

微信小程序javascript

2017-01-09 10:01:49

微信小程序

2017-06-09 10:06:54

微信小程序架構(gòu)分析

2017-06-09 10:40:00

微信小程序架構(gòu)分析

2017-06-09 12:58:20

微信小程序架構(gòu)分析

2016-11-04 10:31:49

微信程序指南

2016-09-28 18:10:59

微信程序MINA

2016-11-22 11:23:52

微信小程序騰訊微信

2016-09-27 16:38:24

JavaScript微信Web

2021-06-10 10:51:27

程序基礎(chǔ)架構(gòu)

2016-11-04 10:49:48

微信小程序

2016-09-27 15:40:58

微信程序前端

2016-11-19 18:06:44

微信小程序張小龍

2017-06-27 10:53:32

2016-09-27 20:36:23

微信HttpWeb

2017-02-06 13:32:12

微信小程序思想

2017-11-13 16:35:36

iPhone X全面屏APP

2016-11-04 09:55:16

微信小程序
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 一级免费毛片 | 亚洲人成网站777色婷婷 | 日本 欧美 三级 高清 视频 | 亚洲视频免费一区 | 欧美啪啪 | 亚洲精品v日韩精品 | 91porn国产成人福利 | 久久国产亚洲 | 国产精品99久久久久久宅男 | 亚洲成av人片在线观看 | www.四虎.com| 国产精品日本一区二区在线播放 | 日韩网站在线 | 中文字幕一区在线观看视频 | 狠狠亚洲 | 999久久久久久久久6666 | 欧美一级片免费看 | 日韩中文字幕在线不卡 | 国产第一页在线观看 | 日韩二区 | 在线免费看毛片 | 99久久成人 | 99综合| 逼逼网| caoporn免费在线视频 | 国产精品久久久久久久岛一牛影视 | 在线观看免费观看在线91 | 日韩网| 日韩在线视频一区 | 国产高清一区二区 | 欧美日韩在线观看视频网站 | 亚洲免费视频在线观看 | 久久777 | 亚洲天堂av在线 | 日本一二区视频 | 日本三级电影在线观看视频 | av日日操 | 国产在线观看一区二区 | 亚洲精品乱码久久久久久蜜桃91 | 日韩精品视频一区二区三区 | 81精品国产乱码久久久久久 |