React Native 全栈开发实战班 - 用户界面进阶之响应式设计实践
在移动应用开发中,响应式设计 是确保应用在不同设备、屏幕尺寸和方向下都能提供良好用户体验的关键。React Native 提供了多种工具和技巧来实现响应式设计,包括 Flexbox 布局、动态样式、屏幕尺寸适配等。本章节将详细介绍如何在 React Native 中进行响应式设计,包括布局适配、字体适配、组件适配以及常见的设计模式。
5.1 响应式设计概述
响应式设计 的目标是使应用界面能够根据不同的设备和屏幕尺寸自动调整布局和样式,以提供一致的用户体验。响应式设计的主要挑战包括:
- 不同屏幕尺寸: 从小型手机到大型平板。
- 不同屏幕方向: 纵向和横向。
- 不同分辨率和像素密度: 高分辨率设备需要更高质量的图片和图标。
- 不同平台: iOS 和 Android 平台有不同的设计规范和用户习惯。
React Native 提供了多种工具和技巧来应对这些挑战,包括 Flexbox 布局、动态样式、屏幕尺寸 API 等。
5.2 使用 Flexbox 实现响应式布局
Flexbox 是 React Native 中默认的布局系统,能够轻松实现响应式布局。
5.2.1 Flex 属性
-
flex
属性: 定义子元素在主轴方向上占据剩余空间的比例。<View style={{ flex: 1 }}><View style={{ flex: 1, backgroundColor: '#f0f0f0' }} /><View style={{ flex: 2, backgroundColor: '#d0d0d0' }} /> </View>
-
flexDirection
属性: 定义主轴方向(row
或column
)。<View style={{ flexDirection: 'row' }}><View style={{ flex: 1 }} /><View style={{ flex: 2 }} /> </View>
-
justifyContent
属性: 定义子元素在主轴上的对齐方式。<View style={{ justifyContent: 'space-between' }}><View /><View /> </View>
-
alignItems
属性: 定义子元素在交叉轴上的对齐方式。<View style={{ alignItems: 'center' }}><View /><View /> </View>
5.2.2 百分比宽度和高度
React Native 不直接支持百分比宽度和高度,但可以通过 Dimensions
API 实现。
示例:
import React from 'react';
import { View, Text, StyleSheet, Dimensions } from 'react-native';const { width, height } = Dimensions.get('window');const ResponsiveView = () => {return (<View style={styles.container}><View style={[styles.box, { width: width * 0.8, height: height * 0.2 }]} /><View style={[styles.box, { width: width * 0.6, height: height * 0.3 }]} /></View>);
};const styles = StyleSheet.create({container: {flex: 1,justifyContent: 'center',alignItems: 'center',},box: {backgroundColor: '#f0f0f0',margin: 10,},
});export default ResponsiveView;
5.2.3 FlexWrap
flexWrap
属性可以控制子元素是否换行,适用于布局内容较多的情况。
示例:
<View style={{ flexWrap: 'wrap', flexDirection: 'row' }}><View style={{ width: 100, height: 100, backgroundColor: '#f0f0f0', margin: 5 }} /><View style={{ width: 100, height: 100, backgroundColor: '#d0d0d0', margin: 5 }} /><View style={{ width: 100, height: 100, backgroundColor: '#f0f0f0', margin: 5 }} />{/* 更多子元素 */}
</View>
5.3 动态样式
动态样式可以根据屏幕尺寸、设备类型、主题等动态调整组件的样式。
5.3.1 使用 useWindowDimensions
useWindowDimensions
Hook 可以获取当前窗口的宽度、高度和方向。
示例:
import React from 'react';
import { View, Text, StyleSheet, useWindowDimensions } from 'react-native';const ResponsiveText = () => {const { width, height, fontScale } = useWindowDimensions();return (<View style={styles.container}><Text style={{ fontSize: width * 0.05 }}>Responsive Text</Text></View>);
};const styles = StyleSheet.create({container: {flex: 1,justifyContent: 'center',alignItems: 'center',},
});export default ResponsiveText;
5.3.2 条件样式
可以根据屏幕尺寸或方向条件性地应用样式。
示例:
import React, { useState, useEffect } from 'react';
import { View, Text, StyleSheet, Dimensions } from 'react-native';const { width } = Dimensions.get('window');const ResponsiveBox = () => {const [isSmallScreen, setIsSmallScreen] = useState(width < 600);useEffect(() => {const updateLayout = () => {const { width } = Dimensions.get('window');setIsSmallScreen(width < 600);};Dimensions.addEventListener('change', updateLayout);return () => {Dimensions.removeEventListener('change', updateLayout);};}, []);return (<View style={isSmallScreen ? styles.smallContainer : styles.largeContainer}><Text>Responsive Box</Text></View>);
};const styles = StyleSheet.create({smallContainer: {flex: 1,backgroundColor: '#f0f0f0',padding: 10,},largeContainer: {flex: 1,backgroundColor: '#d0d0d0',padding: 20,},
});export default ResponsiveBox;
5.4 屏幕尺寸适配
React Native 提供了 Dimensions
API 和 useWindowDimensions
Hook 来获取屏幕尺寸和方向。
5.4.1 使用 Dimensions
Dimensions
API 可以获取设备屏幕的宽度、高度和像素密度。
示例:
import React from 'react';
import { View, Text, StyleSheet, Dimensions } from 'react-native';const { width, height, scale } = Dimensions.get('window');const ScreenDimensions = () => {return (<View style={styles.container}><Text>Width: {width}</Text><Text>Height: {height}</Text><Text>Scale: {scale}</Text></View>);
};const styles = StyleSheet.create({container: {flex: 1,justifyContent: 'center',alignItems: 'center',},
});export default ScreenDimensions;
5.4.2 使用 useWindowDimensions
useWindowDimensions
Hook 提供了一种更简洁的方式来获取屏幕尺寸。
示例:
import React from 'react';
import { View, Text, StyleSheet, useWindowDimensions } from 'react-native';const ScreenDimensions = () => {const { width, height, fontScale } = useWindowDimensions();return (<View style={styles.container}><Text>Width: {width}</Text><Text>Height: {height}</Text><Text>Font Scale: {fontScale}</Text></View>);
};const styles = StyleSheet.create({container: {flex: 1,justifyContent: 'center',alignItems: 'center',},
});export default ScreenDimensions;
5.5 响应式设计模式
以下是一些常见的响应式设计模式:
5.5.1 流式布局
使用 Flexbox 实现流式布局,使组件能够根据屏幕尺寸自动调整大小和位置。
示例:
import React from 'react';
import { View, Text, StyleSheet } from 'react-native';const FluidLayout = () => {return (<View style={styles.container}><View style={styles.item}><Text>Item 1</Text></View><View style={styles.item}><Text>Item 2</Text></View><View style={styles.item}><Text>Item 3</Text></View></View>);
};const styles = StyleSheet.create({container: {flex: 1,flexDirection: 'row',flexWrap: 'wrap',justifyContent: 'center',alignItems: 'center',},item: {width: 100,height: 100,backgroundColor: '#f0f0f0',margin: 10,justifyContent: 'center',alignItems: 'center',},
});export default FluidLayout;
5.5.2 相对布局
使用相对布局,使组件能够根据其他组件的位置和大小进行调整。
示例:
import React from 'react';
import { View, Text, StyleSheet } from 'react-native';const RelativeLayout = () => {return (<View style={styles.container}><View style={styles.box1}><Text>Box 1</Text></View><View style={styles.box2}><Text>Box 2</Text></View></View>);
};const styles = StyleSheet.create({container: {flex: 1,position: 'relative',},box1: {position: 'absolute',top: 50,left: 50,width: 100,height: 100,backgroundColor: '#f0f0f0',justifyContent: 'center',alignItems: 'center',},box2: {position: 'absolute',bottom: 50,right: 50,width: 100,height: 100,backgroundColor: '#d0d0d0',justifyContent: 'center',alignItems: 'center',},
});export default RelativeLayout;
5.5.3 媒体查询
虽然 React Native 不支持传统的 CSS 媒体查询,但可以通过 Dimensions
API 和 useWindowDimensions
Hook 实现类似的媒体查询效果。这样就可以根据屏幕尺寸做不同的样式,甚至可以写多套的方式,来直接区分风格太大的模块。
作者简介
前腾讯电子签的前端负责人,现 whentimes tech CTO,专注于前端技术的大咖一枚!一路走来,从小屏到大屏,从 Web 到移动,什么前端难题都见过。热衷于用技术打磨产品,带领团队把复杂的事情做到极简,体验做到极致。喜欢探索新技术,也爱分享一些实战经验,帮助大家少走弯路!
温馨提示:可搜老码小张公号联系导师
相关文章:
React Native 全栈开发实战班 - 用户界面进阶之响应式设计实践
在移动应用开发中,响应式设计 是确保应用在不同设备、屏幕尺寸和方向下都能提供良好用户体验的关键。React Native 提供了多种工具和技巧来实现响应式设计,包括 Flexbox 布局、动态样式、屏幕尺寸适配等。本章节将详细介绍如何在 React Native 中进行响应…...
SlickGrid点击/双击事件
分析 SlickGrid提供了点击事件方法grid.onClick和grid.onDblClick用于捕获用户对表格列的点击,捕获到点击事件之后,修改表格数据,然后使用grid.updateRow方法将修改后的数据更新到表格中。 展示 代码 创建grid(HTML)…...
一文详细深入总结服务器选型
1. 题记: 服务器选型工作是项目规划检讨的一项非常重要的工作,本文详细深入总结服务器选型。 2. 服务器基础知识概览 2.1 服务器的定义与功能 2.1 .1 定义 服务器是一种高性能计算机,其设计目的是在网络中提供服务。它可以处理来自多个客…...
一、Nginx反向代理(七层代理)二、Nginx的TCP/UDP调度器(四层代理)
一、Nginx反向代理(七层代理) 实验要求 使用Nginx实现Web反向代理功能,实现如下功能: 后端Web服务器两台,可以使用httpd实现Nginx采用轮询的方式调用后端Web服务器两台Web服务器的权重要求设置为不同的值最大失败次数为…...
CSS+JQuery 实现弹力球效果,碰到屏幕边框弹回
实现弹力球效果,碰到屏幕边框弹回,效果如下 代码如下: <img src"../image/ball.png" alt"" class"ball"> <style>.ball {position: fixed;top: 50vh;left: 50vw;width: 15vw;height: 15vw;border…...
shell编程规范和脚本变量
什么是shell 人和计算机内核之间的中介: 计算机的语言是二进制,把人类的语言翻译成计算机能够识别的语言,然后让内核来处理 内核完成之后要把结果反馈给用户,要把计算机的翻译成人类能够识别的语言 命令解释器,pyc…...
jspm美容院管理系统
摘要 首先,论文一开始便是清楚的论述了系统的研究内容。其次,剖析系统需求分析,弄明白“做什么”,分析包括业务分析和业务流程的分析以及用例分析,更进一步明确系统的需求。然后在明白了系统的需求基础上需要进一步地设计系统,主要包罗软件架构模式、整体功能模块、数据库设计…...
Prometheus结合K8s(二)使用
上一篇介绍了如何搭建 Prometheus结合K8s(一)搭建-CSDN博客,这章介绍使用 页面访问 kubectl get svc -n prom 看promeheus和granfana的端口访问页面 Prometheus 点击status—target,可以看到metrics的数据来源,即各…...
【虚幻引擎】UE5数字人开发实战教程
本套课程将会交大家如何去开发属于自己的数字人,包含大模型接入,流式输出,语音识别,语音合成,口型驱动,动画蓝图,语音唤醒等功能。 课程介绍视频如下: 【虚幻引擎】UE5 历时一个多月…...
深入分析:固定参考框架在RViz中的作用与对数据可视化的影响 ros ubuntu20.04
深入分析:固定参考框架在RViz中的作用与对数据可视化的影响 RViz (Robot Visualization) 是 ROS (Robot Operating System) 中一种重要的三维可视化工具,主要用于实时观察和分析传感器数据、机器人状态信息以及环境模型。RViz的核心功能之一是固定参考框…...
Android:时间选择器(最下面有效果图)
1.创建DateUtil类 /*** Created by wangshuai on 2024/11/19.*/ public class DateUtil {public final static String PATTERN_ALL"yyyy-MM-dd HH:mm:ss";public final static String PATTERN_DEFAULT"yyyy-MM-dd";/*** 获取当前时间* return yyyy-MM-dd*…...
第十六届蓝桥杯模拟赛(第一期)-c++/c
c/c蓝桥杯模拟赛题解,非常详细 质因数 1、填空题 【问题描述】 如果一个数 p 是个质数,同时又是整数 a 的约数,则 p 称为 a 的一个质因数。 请问 2024 有多少个质因数。 【答案提交】 这是一道结果填空的题,你只需要算出结果后提…...
如何挑选路由器?需要看哪些参数?
挑选路由器时,选择合适的型号和参数对于确保家庭或办公网络的速度、稳定性和覆盖范围至关重要。以下是挑选路由器时需要考虑的关键参数和因素: 1. 无线标准 (Wi-Fi标准) 无线标准是衡量路由器性能的核心指标。不同的无线标准提供不同的速率、范围和技术…...
mysql-备份(二)
前章介绍了MySQL的内部数据结构btree,这章讲述mysql的备份 1:环境 ubuntu22.04 LST mysql5.7.42 or win10 mysql5.7.44 (这里图简单直接windows部署) download:https://downloads.mysql.com/archives/community/ 2:install 1> unzip mysql-5.7.44-w…...
Tailwind CSS 和 UnoCSS简单比较
UnoCSS 和 Tailwind CSS 都是流行的原子化 CSS 框架,但它们在设计理念、性能和使用方式上有一些重要的区别。下面是对它们的详细对比: 1. 概述 Tailwind CSS:Tailwind 是一个原子化的 CSS 框架,提供了大量的预定义类(…...
unity3d————范围检测
目录 知识点一:什么是范围检测 知识点二:如何进行范围检测 问题: Physics.queriesHitTriggers 怎么查看是不是true? QueryTriggerInteraction.UseGlobal 参数意味着是否检测触发器将依据全局设置 Physics.queriesHitTrigge…...
修改this.$confirm的按钮位置、图标、文字及标题
在Vue.js项目中,this.$confirm 通常是基于某些UI库(如Element UI或Ant Design Vue)的对话框确认方法。 以下是基于Element UI的this.$confirm的用法示例。 在此之前,你的项目要已经安装了Element UI,如果没安装话就打…...
SQL MID() 函数详解
SQL MID() 函数详解 SQL 中的 MID() 函数是一个非常有用的字符串处理工具,它允许用户从字符串中提取特定位置的子字符串。这个函数在数据库查询和报告中特别有用,尤其是在需要从较长的文本字段中提取特定信息时。本文将详细介绍 MID() 函数的用法、参数…...
【蓝桥杯备赛】123(前缀和的复杂应用)
5. 前缀和的复杂应用 5.1. 123(4 星) 5.1.1. 题目解析 这道题仍然是求一段区间的和,很容易能够想到前缀和找规律: 1------------------1 号块 1 2----------------2 号块 1 2 3--------------3 号块 1 2 3 4------------4 号…...
MINES
MINES (m)6A (I)dentification Using (N)anopor(E) (S)equencing Tombo(v1.4) 命令在 MINES 之前执行: (仅在 fast5 文件中尚未包含 fastq 时需要) tombo preprocess annotate_raw_with_fastqs --fast5-basedir /fast5_dir/ --fastq-file…...
H.265流媒体播放器EasyPlayer.js H5流媒体播放器关于如何查看手机端的日志信息并保存下来
现今流媒体播放器的发展趋势将更加多元化和个性化。人工智能的应用将深入内容创作、用户体验优化等多个方面,带来前所未有的个性化体验。 EasyPlayer.js H.265流媒体播放器属于一款高效、精炼、稳定且免费的流媒体播放器,可支持多种流媒体协议播放&#…...
uni-app快速入门(十一)--常用JS API(上)
在前面学习了uni-app的布局、组件、路由等知识点以后,还要掌握uni-app的JS API ,也可以理解为基于uni-app的java script。本节介绍uni-app的request请求、文件上传、数据缓存、获取位置、获取系统信息、获取手机的网络状态、拨打电话API。 一、request请求 使用uni…...
Flink任务提交到yarn上slot数量为0的问题
现象:Flink提交到yarn上slot数量为0的问题 解决方法: 参考论坛上的方案,修改flink-conf.yaml文件都不管用 最终解决方法: $FLINK_HOME/lib 路径下有2个非.jar结尾的文件,把这几个文件移走之后,再启就可…...
vue3怎么根据字符串获取组件实例
例子: 我在使用vue2开发的时候,定义了一个方法 handler(strRef){ this.$refs[strRef].innerText hello world }, 我在点击某个按钮的时候,调用了方法handler,传递了一个参数是字符串 condition,然后方法…...
ISUP协议视频平台EasyCVR私有化视频平台新能源汽车充电停车管理方案的创新与实践
在环保意识提升和能源转型的大背景下,新能源汽车作为低碳出行的选择,正在全球迅速推广。但这种快速增长也引发了充电基础设施短缺和停车秩序混乱等挑战,特别是在城市中心和人口密集的居住区,这些问题更加明显。因此,开…...
智领未来: 宏集物联网HMI驱动食品与包装行业迈向智能化新高度
行业现状与挑战 食品与包装行业对设备的自动化、智能化水平要求日益提高,特别是瓶装和灌装生产线需要实现高速、高效的生产。此外,该行业还需遵循严格的卫生标准和安全规范,以保证产品质量符合消费者需求。在提高生产效率的同时,…...
redis-击穿、穿透、雪崩
击穿、穿透、雪崩经常听人说吧? 那他到底是啥呢?无非就是在有缓存层的情况下,对各种绕过缓存层从而直接落到了DB上的情况进行的分类。 概念性的东西大概如下,我是记不住,后期具体使用与规避这些问题才是大事ÿ…...
【Redis】服务器异常重启,导致redis启动失败
redis启动失败日志提示信息:Bad file format reading the append only file: make a backup of your AOF file, then use ./redis-check-aof --fix <filename> 错误日志示例图(看最后一句) 错误原因解析 这个错误通常是由于Redis的…...
Springboot+Vue的项目搭建(三)
一、拦截器 拦截器(Interceptor)是一种重要的软件设计模式,它在程序执行过程中能够拦截或截取特定的操作或事件,并在操作发生之前、之后或替代操作本身进行自定义的处理。以下是对拦截器知识点的详细归纳: 拦截器的定…...
【Word】一键批量引用论文上标——将正文字体改为上标格式
【Word】一键批量引用论文上标——将正文字体改为上标格式 写在最前面Word一键批量引用论文上标技巧分享核心思路:Word 替换功能 通配符步骤详解1. 打开 Word 替换功能2. 输入通配符模式3. 设置替换格式为上标4. 批量替换 实际效果展示技巧扩展 🌈你好呀…...
wordpress 注释代码/西安搜索引擎优化
模板介绍 精美PPT模板设计,绿色简约线条图表合集PPT模板。一套可视图表幻灯片模板,内含黑色,绿色多种配色,精美风格设计,动态播放效果,精美实用。 一份设计精美的PPT模板,可以让你在汇报演讲时脱颖而出。…...
高端做网站/上海优化公司有哪些
以前一直以为IIS应用程序的默认文档只能设置根目录下的文件,像index.html,default.aspx等,后来经同事指点,原来子目录或者子应用程序下的文件也可以添加到根应用程序的默认文档列表中。之 前为了实现这样的需求,当用户…...
做网站做软件怎么赚钱吗/全自动推广软件
1.输出函数 - print 用法一:print(数据) 在控制台打印指定数据,打印结束后会自动换行 print(你好世界)用法二:print(数据1,数据2,数据3,…) 一行同时打印多个数据,每个数据空格隔开…...
北京网络营销推广外包/一键优化软件
环境介绍:zabbix版本:3.0.5操作系统:Centos6.8IP地址:192.168.10.1502. 安装sendEmailsendEmail是一个免费、轻量级、命令行的SMTP邮件客户端。如果你需要使用命令行方式发送邮件,那么sendEmail是非常完美的选择&#…...
wordpress html 单页/黑马it培训班出来现状
element-UI 根据table中数据改变颜色 或显示对应内容 1、根据table中数据的值改变显示颜色,效果:代码: <el-table-column prop"countdown" label"剩余天数(天)" width"95"><template scope"scop…...
泗洪有做网站/酒店营销推广方案
php实现mysql同步的实现方法拿到需求之后,发现这两个网站的MYSQL数据库都不能远程访问(安全第一吧)。于是想起了 平时使用的CSV文件批量录入数据。于是尝试使用CSV导入导出。导入到处框架如下:1首先将数据导出成CSV的格式。建立一文件,放置在…...