WHAT - React Native 中 Light and Dark mode 深色模式(黑暗模式)機制

文章目錄

  • 一、Light / Dark Mode 的原理
    • 1. 操作系統層
    • 2. React Native 如何獲取?
    • 3. 樣式怎么跟著變?
  • 二、關鍵代碼示例講解
    • 代碼講解:
  • 三、自定義主題
  • 四、運行時自動更新
  • 五、核心原理一張圖
  • 組件應用例子
    • 最小示例:動態樣式
    • 按鈕的動態樣式
    • 如何封裝一套自定義主題
    • 四、如何和 ThemeProvider 配合?
    • 小技巧
    • 總結
  • 總結一句話

這其實是現代移動應用開發中非常常用的功能:自動適配淺色/深色模式(Light / Dark Mode)。

在業內,譬如 React Native + Expo 把這個機制做得非常友好,下面我幫你從原理到代碼一步步拆解,讓你徹底理解它是如何工作的。

一、Light / Dark Mode 的原理

1. 操作系統層

所有的主流操作系統(Android、iOS、macOS、Windows)都提供了「全局配色方案」設置:

  • 淺色(Light)
  • 深色(Dark)

當用戶在系統里選擇了一個模式后,操作系統會把這個偏好傳遞給應用程序


2. React Native 如何獲取?

React Native 暴露了一個 hook

const colorScheme = useColorScheme();

這個 hook:

  • 自動監聽系統主題
  • 返回 'light''dark'null

例如:

const colorScheme = useColorScheme();
console.log(colorScheme);
// 可能打印:'light' 或 'dark'

一旦系統主題改變(比如用戶切換深色模式),React Native 會自動重新渲染你的組件。


3. 樣式怎么跟著變?

知道當前主題后,你就可以:

  • 切換顏色
  • 切換主題對象
  • 切換字體或其他樣式

Expo Router 的模板里,就是通過 <ThemeProvider> 提供一個全局主題對象:

<ThemeProvider value={colorScheme === 'dark' ? DarkTheme : DefaultTheme}>
  • 當 colorScheme 是 'dark',使用 DarkTheme
  • 當 colorScheme 是 'light',使用 DefaultTheme

所有內部的組件(如導航、背景色、按鈕)就都自動使用對應的顏色配置。


二、關鍵代碼示例講解

來看你提到的核心代碼:

return (<ThemeProvider value={colorScheme === 'dark' ? DarkTheme : DefaultTheme}><Stack><Stack.Screen name="(tabs)" options={{ headerShown: false }} /><Stack.Screen name="+not-found" /></Stack><StatusBar style="auto" /></ThemeProvider>
);

代碼講解:

useColorScheme()

  • 獲取系統主題

ThemeProvider

  • 提供全局主題對象
  • 內部的 StackTabDrawer 會自動根據這個 Theme 渲染樣式(背景、字體顏色、分隔線等)

DarkThemeDefaultTheme

  • 都是內置的主題對象

  • 定義了:

    • 主色
    • 背景色
    • 文本顏色
    • 邊框色
    • 卡片顏色

StatusBar style="auto"

  • 自動根據主題切換狀態欄字體顏色(黑色/白色)

三、自定義主題

如果你想擴展自己的配色,可以在 themes.ts 文件定義:

export const MyLightTheme = {...DefaultTheme,colors: {...DefaultTheme.colors,primary: '#1e90ff',background: '#ffffff',text: '#333333',},
};export const MyDarkTheme = {...DarkTheme,colors: {...DarkTheme.colors,primary: '#1e90ff',background: '#000000',text: '#ffffff'

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

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

相關文章

[25-cv-07396、25-cv-07470]Keith代理Anderson這9張版權圖,除此之外原告還有50多個版權!賣家要小心!

Anderson 版權圖 案件號&#xff1a;25-cv-07396、25-cv-07470 立案時間&#xff1a;2025年7月2日 原告&#xff1a;Anderson Design Group, Inc. 代理律所&#xff1a;Keith 原告介紹 原告是美國的創意設計公司&#xff0c;成立于1993年&#xff0c;簡稱ADG&#xff0c;一…

五、代碼生成器:gen項目開發

目錄 1.新建數據庫 2.nacos中配置文件 3.gen項目配置代碼 4.前端項目 我們再項目中需要代碼生成器,這邊自己開發一個gen代碼生成器服務。 1.新建數據庫 CREATE TABLE `gen_table` (`table_id` bigint NOT NULL AUTO_INCREMENT COMMENT 編號,`table_name` varchar(200) DEF…

UI前端大數據處理安全性保障:數據加密與隱私保護策略

hello寶子們...我們是艾斯視覺擅長ui設計、前端開發、數字孿生、大數據、三維建模、三維動畫10年經驗!希望我的分享能幫助到您!如需幫助可以評論關注私信我們一起探討!致敬感謝感恩! 一、引言&#xff1a;大數據時代前端安全的核心挑戰 在數據驅動業務發展的今天&#xff0c;U…

基于 alpine 構建 .net 的基礎鏡像

準備基礎鏡像 alpine:3.22 完整的 Dockerfile 如下&#xff1a; # 使用官方的 Alpine 3.22 鏡像作為基礎鏡像 FROM --platform$TARGETPLATFORM alpine:3.22 AS builder# 設置環境變量 ENV DEBIAN_FRONTENDnoninteractive# 創建目錄結構 WORKDIR /app# 備份原始源文件并更換為…

Blob分析及形態學分析

目錄 Blob分析的基本思想&#xff1a; Blob分析主要流程&#xff1a; Blob分析 分割: Binary Threshold 分割: Histogram 分割: 動態閾值 全局閾值與動態局部閾值的比較 形態學處理 連通區域 connetion 形態學算子 特征提取 提取特征 常用相關算子 區域特征&#…

中小河流雨水情監測預報系統解決方案

一、方案概述 中小河流在防洪減災體系中地位關鍵&#xff0c;但由于其數量眾多、分布廣泛&#xff0c;監測預報基礎相對薄弱&#xff0c;易引發洪水災害&#xff0c;威脅沿岸居民生命財產安全。本系統旨在構建完善的中小河流雨水情監測預報體系&#xff0c;提升防洪減災能力。實…

Abase和ByteKV存儲方案對比

Abase 和 ByteKV 是字節跳動內部自研的兩款分布式 KV 存儲系統&#xff0c;雖然都服務于大規模在線業務&#xff0c;但在設計目標、架構模型、適用場景等方面存在顯著差異。以下是核心區別的詳細分析&#xff1a; &#x1f527; ?1. 設計目標與一致性模型? ?Abase?&#x…

JSON的縮進格式方式和緊湊格式方式

將對象轉化為json格式字符串在以縮進的方式顯示 HxParamMsg hxCommMsg new HxParamMsg() {name "Tom",age 25 }; string json JsonConvert.SerializeObject(hxCommMsg); var parsed JToken.Parse(json); string data parsed.ToString(Formatting.Indented); // …

設計模式篇:靈活多變的策略模式

引言&#xff1a;從現實世界到代碼世界的面向對象在商業策略制定中&#xff0c;企業會根據市場環境選擇不同的競爭策略&#xff1b;在軍事行動中&#xff0c;指揮官會根據敵情選擇不同的戰術&#xff1b;在游戲對戰中&#xff0c;玩家會根據局勢調整作戰方式。這種根據情境選擇…

Bitvisse SSH Client 安裝配置文檔

一、軟件功能介紹? Bitvisse SSH Client 是一款功能強大的 SSH 客戶端軟件&#xff0c;具備以下顯著特點&#xff1a;? 豐富的代理隧道協議支持&#xff1a;支持 socks4、socks4a、socks5 和 http 等多種連接代理隧道協議&#xff0c;為網絡連接提供多樣選擇。?便捷的應用…

DataGear 5.4.1 發布,數據可視化分析平臺

DataGear 數據可視化分析平臺 5.4.1 發布&#xff0c;BUG修復&#xff0c;具體更新內容如下&#xff1a; 修復&#xff1a;修復SQL數據集使用預編譯語法后SQL關鍵字防注入功能不起作用的BUG&#xff1b;修復&#xff1a;修復內置圖表選項disableSetting在圖表展示頁不起作用的…

Visual Studio install 解決進度條不加載,自動安裝失敗導致軟件無法打開問題

路徑 C:\Windows\System32\drivers\etc修改hosts文件&#xff0c;需要右鍵管理員權限打開。 # Copyright (c) 1993-2009 Microsoft Corp. # # This is a sample HOSTS file used by Microsoft TCP/IP for Windows. # # This file contains the mappings of IP addresses to h…

關于小波降噪、小波增強、小波去霧的原理區分

在傳統的圖像處理中使用小波分解是一種常見的方法。經常分不清小波降噪和小波增強的區別&#xff0c;簡單記錄下二者的區別同時再記錄一下小波去霧的原理。一、小波降噪原理信號分解小波降噪基于小波變換。它將含噪信號分解成不同尺度&#xff08;頻率&#xff09;下的小波系數…

Python商務數據分析——Matplotlib 數據可視化學習筆記

一、Matplotlib 基礎認知 1.1 庫功能與定位 核心作用&#xff1a;將數據可視化展示&#xff0c;提升數據直觀性與說服力 應用場景&#xff1a;繪制折線圖、餅圖、柱狀圖等 2D/3D 圖表 雙接口模式&#xff1a; MATLAB 風格&#xff1a;通過pyplot函數快速繪圖&#xff08;自…

GIC控制器(一)

目錄 處理器工作模式 異常源 ?編輯寄存器組織結構 異常處理流程 CPSR寄存器 異常向量表 編寫異常向量表 CP15協處理器 CP15 協處理器寄存器分組 協處理器指令 C0寄存器 C1寄存器 C12寄存器 C15寄存器 CBAR寄存器 Reset異常 前言&#xff1a; GIC&#xff08;G…

深入解析RS485通信:從原理到Linux驅動開發實踐

深入解析RS485通信&#xff1a;從原理到Linux驅動開發實踐在工業控制、智能建筑和物聯網領域&#xff0c;RS485憑借其強大的抗干擾能力和多節點組網特性&#xff0c;成為長距離可靠通信的首選方案。本文將帶您深入理解RS485的核心技術。一、RS485通信技術解析 1.1 RS485與RS232…

Linux系統常用性能分析運維命令

分類命令描述CPU性能分析相關命令mpstat -P ALL 5監控所有CPU的使用情況&#xff0c;間隔5秒后輸出一組數據。用于查看是否出現某個CPU占滿的情況CPU性能分析相關命令pidstat -u 5 1監控所有進程的CPU使用情況&#xff0c;用于查看是否出現某個進程CPU占用過高的問題CPU性能分析…

HTTP 壓縮

介紹 壓縮是提升網站性能的關鍵手段之一。對于某些類型的文件&#xff0c;最大可減少 70% 的大小&#xff0c;從而大幅降低帶寬需求。隨著時間的推移&#xff0c;壓縮算法不斷得到優化&#xff0c;新的高效算法也逐漸被客戶端和服務器所支持。 在實際應用中&#xff0c;Web 開…

STM32之循跡避障模塊TCRT5000紅外反射傳感器

目錄 一、系統概述 二、TCRT5000紅外反射傳感器簡介 2.1 基本概述 2.2 結構與工作原理 2.2.1 物理結構 2.2.2 工作流程 2.2.3 電路原理圖 2.3 電氣特性 2.4 模塊接口說明 2.5 典型應用電路 2.6 實際應用注意事項 三、硬件設計 3.1 硬件組成 3.2 硬件連…

新能源汽車功率級測試自動化方案:從理論到實踐的革命性突破

> 在800V高壓平臺普及與碳化硅半導體爆發的雙輪驅動下,傳統測試方法正經歷顛覆性變革 “當我看到工程師手動記錄測試數據時,就知道這個行業需要一場革命。”——某新能源車企測試總監的深夜感慨 ## 01 新能源汽車測試的痛點與變革 當新能源汽車的**電驅系統功率密度突…