淺談Web自適應

来源:http://www.cnblogs.com/agileai/archive/2016/08/19/5787797.html
-Advertisement-
Play Games

前言 隨著移動設備的普及,移動web在前端工程師們的工作中占有越來越重要的位置。移動設備更新速度頻繁,手機廠商繁多,導致的問題是每一臺機器的屏幕寬度和解析度不一樣。這給我們在編寫前端界面時增加了困難,適配問題在當下顯得越來越突出。記得剛剛開始開發移動端產品的時候向設計MM要了不同屏幕的設計圖,結果可 ...


前言

隨著移動設備的普及,移動web在前端工程師們的工作中占有越來越重要的位置。移動設備更新速度頻繁,手機廠商繁多,導致的問題是每一臺機器的屏幕寬度和解析度不一樣。這給我們在編寫前端界面時增加了困難,適配問題在當下顯得越來越突出。記得剛剛開始開發移動端產品的時候向設計MM要了不同屏幕的設計圖,結果可想而知。本篇博文分享一些滷煮處理多屏幕自適應的經驗,希望有益於諸君。

特別說明:在開始這一切之前,請開發移動界面的工程師們在頭部加上下麵這條meta:

簡單事情簡單做-寬度自適應

所謂寬度自適應嚴格來說是一種PC端的自適應佈局方式在移動端的延伸。在處理PC端的前端界面時候需要用到全屏佈局時採用的就是此種佈局方式。它的實現方式也比較簡單,將外層容器元素按照百分比鋪滿地方式,裡面的子元素固定或者左右浮動。

由於父級元素採用百分比的佈局方式,隨著屏幕的拉伸,它的寬度會無限的拉伸。而子元素由於採用了浮動,那麼它們的位置也會固定在兩端。該寬度自適應在新的時代有了新的方法,隨著彈性佈局的普及,它經常被flex或者box這樣的伸縮性佈局方式替代,變得越來越“彈性”十足。需要瞭解彈性佈局,請前往Flex佈局教程和滷煮box佈局教程比較。

大小之辨-完全自適應

“完全自適應式”是滷煮對越此方案的叫法,由於滷煮現在找不到官方名稱,所以暫時就這樣叫它。這種解決方案相對前一種來說進步不少,不僅僅寬度實現了自適應,而且界面所有的元素大小和高度都會根據不同解析度和屏幕寬度的設備來調整元素、字體、圖片、高度等屬性的值。簡單來說就是在不同的屏幕下,你看到的字體和元素高寬度的大小是不一樣的。在這裡,有人就會說利用的是媒體查詢熟悉,根據不同的屏幕寬度,調整樣式。滷煮之前也是這樣想的,但是你需要考慮到界面上的許多元素需要設置字體,如果用media query為每個元素在不同的設備下都設置不同的屬性的話,那麼有多少種屏幕我們的css就會增加多少倍。實際上在這裡,我們採用的是js和css熟悉rem來解決這個問題的。

REM屬性指的是相對於根元素設置某個元素的字體大小。它同時也可以用作為設置高度等一系列可以用px來標註的單位。

採用以上寫法,div繼承到了html節點的font-size,為本身定義了一系列樣式屬性,此時1em計算為10px,即根節點的font-size值。所以,這時div的高度就是20px,寬度是30px,邊框是1px,字體大小則是10px;一旦有了這樣的方法,我們自然可以根據不同的屏幕寬度設置不同的根節點字體大小。假設我們現在設計的標準是iphone5s,iphone5系列的屏幕解析度是640。為了統一規範,我們將iphone5 解析度下的根元素font-size設置為100px;

那麼以此為基準,可以計算出一個比例值6.4。我們可以得知其他手機解析度的設備下根元素字體大小:

在head中,我們將以上代碼加入,動態地改變根節點的font-size值,得到如下結果:

接下來我們可以根據根元素的字體大小用rem設置各種屬性的相對值。當然,如果是移動設備,屏幕會有一個上下限制,我們可以控制解析度在某個範圍內,超過了該範圍,我們就不再增加根元素的字體大小了:

一般的情況下,你是不需要考慮屏幕動態地拉伸和收縮。當然,假如用戶開啟了轉屏設置,在網頁載入之後改變了屏幕的寬度,那麼我們就要考慮這個問題了。解決此問題也很簡單,監聽屏幕的變化就可以做到動態切換元素樣式:

為了提高性能,讓代碼開起來更加完美,可以為它加上節流閥函數:

順帶解決高保真標註與實際開發值比例問題

如果你們設計稿標準是iphone5,那麼拿到設計稿的時候一定會發現,完全不能按照高保真上的標註來寫css,而是將各個值取半,這是因為移動設備解析度不一樣。設計師們是在真實的iphone5機器上做的標註,而iphone5系列的解析度是640,實際上我們在開發只需要按照320的標準來。為了節省時間,不至於每次都需要將標註取半,我們可以將整個網頁縮放比例,模擬提高解析度。這個做法很簡單,為不同的設備設置不同的meta即可:

這樣設置同樣可以解決在安卓機器下1px像素看起來過粗的問題,因為在像素為1px的安卓下機器下,邊框的1px被壓縮成了0.5px了。總之是一勞永逸!淘寶和網易新聞的手機web端就是採用以上這種方式,自適應各種設備屏幕的,大家有興趣可以去參考參考。下麵是完整的代碼:

讓元素飛起來-媒體查詢

運用css新屬性media query 特性也可以實現我們上說到過的佈局樣式。為尺寸設置根元素字體大小:

這種方式也是可行的,缺點是靈活性不高,取每個設備的精確值需要自己去計算,所以只能取範圍值。考慮設備屏幕眾多,解析度也參差不齊,把每一種機型的css代碼寫出來是不太可能的。但是它也有優點,就是無需監聽瀏覽器的視窗變化,它會跟隨屏幕動態變化。媒體查詢的用法當然不僅僅像在此處這麼簡單,相對於第二種自適應來說有很多地方是前者所遠遠不及的。最明顯的就是它可以根據不同設備顯示不同的佈局樣式!請註意,這裡已經不是改變字體和高度那麼簡單了,它直接改變的是佈局樣式!

此種自適應佈局一般常用在相容PC和手機設備,由於屏幕跨度很大,界面的元素以及遠遠不是改改大小所能滿足的。這時候需要重新設計整界面的佈局和排版了:

如果屏幕寬度大於1300像素

如果屏幕寬度在600像素到1300像素之間,則6張圖片分成兩行。

如果屏幕寬度在400像素到600像素之間,則導航欄移到網頁頭部。

許多css框架經常用到這樣的多端解決方案,著名的bootstrap就是採用此種方式進行柵格佈局的。

總結

不管哪一種自適應方式,我們的目的是使得開髮網頁在各種屏幕下變得好看:如果你的項目定位的用戶群僅僅是使用某種機型的人,那麼可以採用第一種自適應方式。如果你的客戶主要是移動端,但是客戶的設備類型龐雜,建議採用第二種方式。如果你雄心勃勃地需要建立一套相容PC、PAD、mobile多端的一體化web應用,那麼第三種選擇顯然是最適合你的。每種方式都有自己的利弊,根據需求權衡利害,合理地實現自適應佈局,需要不停的實踐和摸索。路漫漫其修遠兮,吾將上下而求索。

參考資料

  • 自適應網頁設計(Responsive Web Design)

  • 移動前端自適應解決方案和比較

  • 移動web適配利器-rem

版權聲明:來源:賣燒烤夫斯基,鏈接:www.cnblogs.com/constantince/p/5708930.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本視頻為activiti工作流的web流程設計器整合視頻教程 整合Acitiviti線上流程設計器(Activiti-Modeler 5.21.0 官方流程設計器) 本視頻共講了兩種整合方式 1. 流程設計器和其它工作流項目分開部署的方式 2. 流程設計器和SSM框架項目整合在一起的方式 視頻大小 ...
  • 先從web session的共用說起 許多系統需要提供7*24小時服務,這類系統肯定需要考慮災備問題,單台伺服器如果宕機可能無法立馬恢復使用,這必定影響到服務。這個問題對於系統規模來說,從小到大可能面臨的難度會相差很大。但對於原理來說其實就是需要準備備份系統隨時可以替代正在服務的系統,也就是無論何時 ...
  • scjp test( 線上測試網站):http://scjptest.com/mock-test.xhtml 《SCJP Sun® Certified Programmer for Java™ 6 Study Guide》(Exam 310-065) PDF Java技能回答網站: 無論你遇到什麼樣... ...
  • 0.前提條件 環境兩台ubuntu版本14.04 64位系統(並獲取root許可權) 假設兩台伺服器ip為:172.16.34.214(master),172.16.34.215(backup),keepalived的虛擬ip為172.16.34.216 兩台ubuntu系統上裝好docker,版本如 ...
  • 1、框模型:盒模型,①對象實際寬度=左右外邊距+左右邊框+左右內邊距 + width;②對象實際高度=上下外邊距+上下邊框+上下內邊距 + height; 2、外邊距:margin:取值:①top(上) right(右) bottom(下) left(左);②value:一個值,四個方向相同;③to ...
  • 輪播圖在以後的應用中還是比較常見的,不需要多少行代碼就能實現。但是在只掌握了js基礎知識的情況下,怎麼來用較少的而且邏輯又簡單的方法來實現呢?下麵來分析下幾種不同的做法: 1、利用位移的方法來實現 首先,我們可以在body中添加一個div並且將寬度設置成百分比(自適應頁面),比例具體是相對誰的百分比 ...
  • [1]創建節點 [2]插入節點 [3]移除節點 [4]替換節點 [5]複製節點 ...
  • 一直對移動項目不是很熟悉,做的很少,用的都是一些百分比,惡補了一下。 一.首先看下頭部。 format-detection翻譯成中文的意思是“格式檢測”,顧名思義,它是用來檢測html里的一些格式的,那關於meta的format-detection屬性主要是有以下幾個設置:meta name="fo ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...