uniapp的適配方式

文章目錄

  • 前言
    • ? 一、核心適配方式對比
    • 📏 二、`rpx` 單位:uni-app 的核心適配機制
    • 🧱 三、默認設計稿適配(750寬)
    • 🔁 四、字體 & 屏幕密度適配
    • 🛠 五、特殊平臺適配(底部安全區、劉海屏)
    • 🧪 六、調試建議
    • 🧰 七、總結:uni-app 的屏幕適配優勢


前言

uni-app 相比普通 H5 頁面,在適配多終端屏幕方面做了大量工作,目標是讓同一套代碼在 App、小程序、H5 等多平臺上視覺一致、布局準確、交互無誤。


? 一、核心適配方式對比

維度普通 H5 頁面uni-app
單位體系px, rem, %, vw/vh統一使用 rpx(響應像素)
設計稿基準通常 750px 或 375px,需手動適配默認設計稿以 750px 寬度為基準
屏幕適配機制開發者手動設置 viewport 和 media query編譯時自動轉換 rpx → 實際像素(各端自適應)
多端兼容性需針對不同終端編寫樣式各端運行時會自動渲染為適配單位(如 App、小程序自動轉換)
字體縮放問題需要 JS 控制或媒體查詢自動處理大字體模式(小程序)和字體縮放(App)兼容性

📏 二、rpx 單位:uni-app 的核心適配機制

  • rpx = responsive pixel(響應式像素)

  • 自動根據屏幕寬度進行縮放:

    • 在 750px 設計稿下,屏幕寬度為 750rpx,自動適配到任意設備
    • 設備寬為 375px(iPhone 6/7/8),則 1rpx = 0.5px
  • 編譯時轉換為各平臺的對應單位:

    • 小程序平臺 → 微信原生 rpx
    • H5 → 轉換為 vw
    • App → 轉換為 px + dpr 縮放

📌 你寫一次:width: 375rpx,在所有平臺都能保持相同視覺寬度!


🧱 三、默認設計稿適配(750寬)

  • 大多數組件、模板、樣式都是以 750px 寬設計稿為基準
  • 若你的設計稿是 375px 寬,也可以通過工具將其轉為 750 再開發
  • rpx 只關注相對寬度,不必手動設置媒體查詢或 DPR 縮放

🔁 四、字體 & 屏幕密度適配

  • 小程序字體縮放兼容:rpx 會自動縮放,不需要額外處理
  • App 字體縮放兼容:uni-app 已處理系統字體縮放問題
  • 不建議使用 px 單位定義字體,否則在高 DPI 設備上易出現大小不一

🛠 五、特殊平臺適配(底部安全區、劉海屏)

uni-app 提供了多平臺兼容性處理:

問題解決方式
iPhone X 底部安全區使用 safe-area-inset-bottom,或 H5 中使用 padding-bottom: constant(safe-area-inset-bottom)
狀態欄高度通過 uni.getSystemInfoSync() 獲取 statusBarHeight
劉海屏/圓角屏App 和小程序平臺會自動適配 padding 區域,建議使用 view 包裹避免遮擋

🧪 六、調試建議

  • 推薦設計稿基準寬度:750px
  • 使用 HBuilderX微信開發者工具 來真實還原 rpx 效果
  • 避免寫死 px 布局(否則會在高分屏上過小)

🧰 七、總結:uni-app 的屏幕適配優勢

優勢描述
? rpx 統一單位一套代碼兼容所有屏幕密度和平臺
? 編譯階段處理無需手動編寫媒體查詢或動態 JS 控制
? 多端兼容性強H5、小程序、App 統一視覺表現
? 安全區處理完善App/iOS/小程序常見異形屏已內建支持

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/906066.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/906066.shtml
英文地址,請注明出處:http://en.pswp.cn/news/906066.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

JAVA EE(進階)_進階的開端

別放棄浸透淚水的昨天,晨光已為明天掀開新篇 ——陳長生. ?主頁:陳長生.-CSDN博客? 📕上一篇:JAVA EE_HTTP-CSDN博客 1.什么是Java EE Java EE(Java Pla…

SQL腳本規范

主要作用:數據庫的備份和遷移 SQL腳本規范 每一個sql語句必須與;結束 腳本結構: { 刪庫,建庫 刪表,建表 插入初始數據 } 建庫語法: CREATE DATABASE 數據庫名CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; CHARA…

std::ratio<1,1000> 是什么意思?

author: hjjdebug date: 2025年 05月 14日 星期三 09:45:24 CST description: std::ratio<1,1000> 是什么意思&#xff1f; 文章目錄 1. 它是一種數值嗎&#xff1f;2. 它是一種類型嗎&#xff1f;3. std:ratio 是什么呢&#xff1f;4. 分析一個展開后的模板函數5.小結: …

測試--測試分類 (白盒 黑盒 單元 集成)

一、按照測試目標分類&#xff08;測試目的是什么&#xff09; 主類別細分說明1. 界面測試UI內容完整性、一致性、準確性、友好性&#xff0c;布局排版合理性&#xff0c;控件可用性等2. 功能測試檢查軟件功能是否符合需求說明書&#xff0c;常用黑盒方法&#xff1a;邊界值、…

整理了 2009 - 2025 年的【199 管綜真題 + 解析】PDF,全套共 34 份文件

每年真題原卷 ? 每年詳細解析 ? &#x1f4c2;【管綜真題 2009-2025】 &#x1f4c2;【管綜解析 2009-2025】 目錄樹&#xff1a; ├── 2009-2025管綜真題 PDF │ ├── 2009年199管綜真題.pdf │ ├── 2010年199管綜真題.pdf │ ├── 2011年199管綜真題.pd…

用golang實現二叉搜索樹(BST)

目錄 一、概念、性質二、二叉搜索樹的實現1. 結構2. 查找3. 插入4. 刪除5. 中序遍歷 中序前驅/后繼結點 一、概念、性質 二叉搜索樹&#xff08;Binary Search Tree&#xff09;&#xff0c;簡寫BST&#xff0c;又稱為二叉查找樹 它滿足&#xff1a; 空樹是一顆二叉搜索樹對…

自動化:批量文件重命名

自動化&#xff1a;批量文件重命名 1、前言 2、效果圖 3、源碼 一、前言 今天來分享一款好玩的自動化腳&#xff1a;批量文件重命名 有時候呢&#xff0c;你的文件被下載下來文件名都是亂七八糟毫無規律&#xff0c;但是當時你下載的時候沒辦法重名或者你又不想另存為重新重…

VueUse/Core:提升Vue開發效率的實用工具庫

文章目錄 引言什么是VueUse/Core&#xff1f;為什么選擇VueUse/Core&#xff1f;核心功能詳解1. 狀態管理2. 元素操作3. 實用工具函數4. 瀏覽器API封裝5. 傳感器相關 實戰示例&#xff1a;構建一個拖拽上傳組件性能優化技巧與原生實現對比常見問題解答總結 引言 在現代前端開發…

stm32 ADC單通道轉換

stm32c8t6僅有12位分辨率 1、單次轉換 非掃描 1、初始化 void Ad_Init() {RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);//配置ADCCLK時鐘分頻,ADC的輸入時鐘不得超過14MHzRCC_ADCCLKConfig(RCC_PCLK2_Div6);G…

2KW壓縮機驅動參考設計【SCH篇】

實物展示&#xff1a; ACDC: VAC和VAC-為交流電壓檢測&#xff1a; 1.C33 C34作為Y電容走線寬度要求&#xff1a; Y電容一般用于L/N到地之間&#xff08;L-PE 或 N-PE&#xff09;&#xff0c;主要作用是抑制共模干擾。其走線的電流非常小&#xff0c;推薦使用 ≥ 1mm 寬的走…

python05——循環結構

1、while循環 n0 #初始條件 while n<5: #判斷print(hello python) #要重復執行的代碼print(n) #注意同級代碼縮進相同n1 #計數器結果&#xff1a; hello python 0 hello python 1 hello python 2 hello python 3 hello python 4 hello python 5 #求階乘和 sum0 n1 whil…

LINUX編譯、運行、測試lowcoder_CN

參考 二者沒有太大差異。 LINUX編譯、運行、測試lowcoder-CSDN博客 下載 git clone https://github.com/mousheng/lowcoder_CN 或 git clone https://gitcode.com/gh_mirrors/lo/lowcoder_CNcd lowcoder_CN三個模塊 node-service api-service client 每個模塊都有自己的…

Python 基礎之函數命名

幾個問題 使用描述性蛇形命名法&#xff08;snake_case&#xff09;Python函數名應使用什么大小寫格式&#xff1f;為什么函數名要具有描述性&#xff1f;方法的命名規范是什么&#xff1f;函數、變量和類的命名有何區別&#xff1f; Python函數的命名有一些不可違背的硬性規…

redis 命令大全整理

http://doc.redisfans.com/ 原網址 Redis 命令分類 Key(鍵) Key(鍵)命令 exists/del/keys/type/scanobject/move/dump/migratettl/pttl/persist/expireat/pexpireat/expire/pexpirerename/renamenxsort/randomkey/restoreexists 語法:exists key [key ...] 檢查一個或多…

React中useDeferredValue與useTransition終極對比。

文章目錄 前言一、核心差異對比二、代碼示例對比1. useDeferredValue&#xff1a;延遲搜索結果更新2. useTransition&#xff1a;延遲路由切換 三、應用場景總結四、注意事項五、原理剖析1. 核心機制對比2. 關鍵差異3. 代碼實現原理 總結 前言 在React的并發模式下&#xff0c…

高并發內存池|定長內存池的設計

二、定長內存池的設計 設計一個定長的內存池&#xff0c;這個內存池的定長在于&#xff0c;當剩余空間使用完畢后&#xff0c;總是開辟相同長度的新空間來使用。我們會使用到一個指針來切割劃分大空間為小空間。大空間是內存池向系統申請的內存大小&#xff0c;而小空間是程序…

微信小程序 自定義圖片分享-繪制數據圖片以及信息文字

一 、需求 從數據庫中讀取頭像&#xff0c;姓名電話等信息&#xff0c;當分享給女朋友時&#xff0c;每個信息不一樣 二、實現方案 1、先將數據庫中需要的頭像姓名信息讀取出來加載到data 數據項中 data:{firstName:, // 姓名img:, // 頭像shareImage:,// 存儲臨時圖片 } 2…

從零開始理解Jetty:輕量級Java服務器的入門指南

目錄 一、Jetty是什么&#xff1f;先看一個生活比喻 二、5分鐘快速入門&#xff1a;搭建你的第一個Jetty服務 步驟1&#xff1a;Maven依賴配置 步驟2&#xff1a;編寫簡易Servlet&#xff08;廚房廚師&#xff09; 步驟3&#xff1a;組裝服務器&#xff08;餐廳開業準備&am…

深入淺出IIC協議 - 從總線原理到FPGA實戰開發 -- 第一篇:I2C總線協議深度解剖

第一篇&#xff1a;I2C總線協議深度解剖 副標題 : 兩根線如何征服千億設備&#xff1f;詳解硬件工程師必須掌握的通信奧義 1. 為什么I2C仍是嵌入式經典&#xff1f; 1.1 總線拓撲的哲學 拓撲對比圖 SPI需4線N片選 vs I2C僅2線級聯 UART點對點 vs I2C多主從架構 成本控制實…

MySQL 索引優化以及慢查詢優化

在數據庫性能優化中&#xff0c;索引優化和慢查詢優化是兩個關鍵環節。合理使用索引可以顯著提高查詢效率&#xff0c;而識別和優化慢查詢則能提升整體數據庫性能。本文將詳細介紹MySQL索引優化和慢查詢優化的方法和最佳實踐。 一、MySQL 索引優化 1.1 索引的基本概念 索引是…