React DAY07

news2025/1/22 8:10:43

复习:

1.RN中的样式和布局

RN样式完全脱离浏览器,自成体系的一套样式,使用对象创建样式
行内样式:

<Text style={{color: 'red'}}>

内部样式:

let ss = StyleSheet.create({danger: {color: 'red'}})
<Text style={ss.danger}>

外部样式:

//style.js
	let gss = StyleSheet.create({danger: {color: 'red'}})
	//Login.js
	<Text style={[gss.danger, {}]}>

布局:弹性布局(display:flex; flex-direction:column;)

2.RN常用组件

View、ScrollView、Text、StatusBar、Image、TextInput、Button、Pressable、TouchableOpacity、FlatList

3.RN常用 JS API

  ①StyleSheet.create()
  ②Alert.alert()
  ③ToastAndroid.show()
  ④AsyncStorage.setItem()/getItem()/removeItem()/clear()
  ⑤useWindowDimensions()

4.RN中的异步请求方法

let  res  =  await  fetch( url, {method, headers, body} )
let  data  =  await  res.json( )

5.RN中的路由导航模块

基于浏览器的React项目中使用的路由模块: react-router-dom
脱离浏览器的React项目中使用的路由模块: react-navigation
①在RN项目中下载必需的模块到node_modules —— 4-5个模块
②重新构建一遍APP的安装文件,得到全新的.apk文件
③在安卓手机中重新安装App,重新配置开发服务器,重启App
④为整个项目中的“页面/屏幕”分配路由地址:App.js
路由器(导航容器) > 路由列表(导航器) > 路由对象(屏幕)*N

  let {Navigator, Screen} = createNativeStackNavigator( )
	  <NavigationContainer>
		<Navigator>
			<Screen name=""  component={}/>
			.....
		</Navigator>
	  </NavigationContainer>

一、React Native组件库

React是一个MVVM框架;
ReactNative是一个基于React框架的移动端UI组件库——是Facebook官方提供的;
官网:https://reactnative.dev/
中文网:https://reactnative.cn/
Vue.js+Vant项目运行原理:

  .vue  =>  Webpack编译  =>  .html/.css/.js   =>   运行于客户端浏览器

React+RN项目运行原理:

  .js/.jsx => Webpack编译  =>  .java或.oc  =>  JAVA或OC编译  =>  .apk或.ipa安装包   =>  安装到手机中运行为原生App(完全脱离浏览器)

(必选操作)运行空白RN项目,在自己的电脑和手机中运行该项目——250MB+
①PC端运行RN项目自带的开发服务器

cd  MyRnApp   &&   npm  start

提示:开发服务器只会占用8081端口

②启动安卓模拟器,安装RN项目编译得到的App

APK路径:MyRnApp\android\app\build\outputs\apk\debug		

③启动手机中的App,在App设置中配置开发服务器的IP和端口号
查看Windows服务器当前的真正IP地址: ipconfig

例如,我当前电脑的IP地址是  192.168.0.105
点击手机“菜单键”> Settings > DebugServerHost&PortForDevice > 输入:
192.168.0.105:8081

④重启手机中的App,会自动连接开发服务器,获取最新的内容

提示:如果出现App闪退、App已停止、App无法启动、App启动后白屏…请重启App、或重新安装App、重启Windows、安装其它的模拟器… 再重试上述几步

二、RN中的样式

第一种:行内样式

<Text  style={{color:'#f00'}}>

第二种:内部样式

let css = StyleSheet.create({	
		danger: {
			color: '#f00',  
		}
	})

第三种:外部样式

说明:
RN中的样式没有“级联”特性,即子组件不会继承父组件的样式——仅有的一个例外:Text中的Text
RN中的样式只能用style属性赋值没有class/className属性——RN组件体系中没有任何一个属性是通用的,例如:有的组件没有style、所有组件都没有className、有的组件没有onClick
style属性可以赋值为一个样式对象,也可以赋值为一个样式对象的数组
RN中可用的样式属性比标准CSS要少得多,例如:没有float、background、border....;有些属性虽然有,但是可用值也比标准CSS少得多,例如:display只有flexnone两种选择
RN的样式中没有“选择器”的概念,样式都是对象
RN中的尺寸单位只有px%,其中px必须省略不写,例如:width: '50%' 或 width: 20 —— 没有rpx、vw、em等单位
字体默认大小14px(记得省略px),可以很大,也可以很小(没有12px的限制)
RN中的布局只有: display: flex(默认值),而且主轴方向默认是“column”
在这里插入图片描述

三、RN中的组件

RN组件的官网手册https://reactnative.cn/docs/components-and-apis
①RN中不能使用HTML组件 —— RN中的组件最终都要编译为JAVA,而HTML标签无法编译
②RN官方提供了20个组件;可以使用这20个组件组合定义出更复杂的自定义组件

RN常用组件:
View:视图,是最简单的容器元素,默认都是“弹性容器”,而且主轴方向是纵向
Text:文本,是最简单的文本元素,RN体系内只有Text中可以放置字符串
Image:图像
本地图片:手机中的图片,必须把开发服务器上的图片进行编译打包,才能装进手机中

<Image source={require('../img/xx.png')}/>   无需指定尺寸

远程图片:图片在远程服务器上,只能通过URL地址来访问

<Image source={{uri: '图片的地址'}}  style={{width, height}}/>   必须指定尺寸

④TextInput:单行文本输入框/单行密码输入框/多行文本输入框,注意:获取输入框中的内容只能使用“类似于普通React项目中的’受控组件’方法”

<TextInput value={uname}  onChangeText={txt=>setUname(txt)}/>
<TextInput secureTextEntry={true}/>
<TextInput multiline={true}/>

⑤StatusBar:控制屏幕顶部状态栏的样式
⑥Button:按钮,在项目中一般不使用(因为没有style属性,无法定制样式),而用Text代替
⑦Pressable:可以按压的,为其它组件提供按压相关事件,onPress / onLongPress / onPressIn(开始按压) / onPressOut(按压结束)
⑧TouchableOpacity:触摸后不透明度可以改变的组件,为其它组件提供用户交互反馈

⑨Modal:弹出一个遮盖住全屏的“模态对话层”,其中的内容可以随意指定
⑩FlatList:平面列表,用于横向/纵向/之字形排列多个元素

四、RN中常用的JS API

ToastAndroid.show( ):弹出吐司对话框——注意:只有Android平台支持
fetch( ):RN官方高仿W3C的fetch标准提供了一套异步请求方法
Alert.alert( ):弹出一个警告对话框(模态对话框)
AsyncStorage.setItem()/getItem()/removeItem()/clear():异步操作客户端本地缓存
useWindowDimensions():获得当前屏幕的尺寸

总结:客户端缓存汇总
H5:sessionStorage或localStorage.setItem() —— 同步方法
uni-app:uni.setStorage()/uni.setStorageSync() —— 异步或同步方法
RN:AsyncStorage.setItem() —— 异步方法
结论:PC机应用中读取缓存文件偏向于使用“同步方法”;手机端应用中读取缓存文件偏向于使用“异步方法”
总结:前端项目中实现AJAX效果的技术有哪些?
①W3C 提供的 XMLHttpRequest:浏览器都支持,但是使用繁琐
②jQuery提供的$.ajax():第三方提供的,底层基于XHR,基于回调
③axios:第三方提供的,既可以用于Node.js应用(基于http模块)也可以用于基于浏览器的应用(基于XHR),Promise
④uni.request:仅用于uni-app项目,底层是对XHR或小程序异步请求方法进一步封装
⑤W3C提供的fetch:行业标准,最新的浏览器都支持,用于取代XHR,基于Promise

五、RN项目中发起异步的服务器端请求

RN官方高仿W3C的fetch标准提供了一套异步请求方法

//使用fetch发起GET请求
let url = "..."
//向指定URL发起异步请求,等待得到响应消息
let res = await fetch( url )
//读取响应消息主体,直至读完,再进行JSON解析
let data = await res.json( )	


//使用fetch发起POST请求
let url = "..."
let options = {
    method: 'POST',
    headers: {'Content-Type':  'application/json'},
    body: JSON.stringif( {k:v, k:v, ...} )
}
//向指定URL发起异步请求,等待得到响应消息
let res = await fetch( url, options )
//读取响应消息主体,直至读完,再进行JSON解析
let data = await res.json( )
总结:
Vue.js项目中的路由导航模块:  
      vue-router
uni-app项目中的路由和导航模块:  
      路由词典pages.json、路由跳转uni.navigateTo()/...
React项目中的路由和导航模块:
      基于浏览器的应用(即网站/H5): react-router-dom
      脱离浏览器的应用(即RN): react-navigation

六、RN项目中的路由和导航模块

RN项目中使用第三方模块 react-navigation 来实现路由和导航功能;
官网:https://reactnavigation.org/ 最新版本:6.x
使用步骤:
①在RN项目中安装必需的react-navigation相关模块

npm install @react-navigation/native
	npm install react-native-screens 
	npm install react-native-safe-area-context
	npm install @react-navigation/native-stack    	如果需要栈式导航
	npm install @react-navigation/bottom-tabs		如果需要底部标签页式导航

②使用之前安装好的3GB+安卓构建环境,重新构建一遍APP安装文件

npx  react-native  run-android

③在安卓模拟器中重新安装App,重新设置开发服务器的IP和端口号,重新启动App
④创建必需的“页面/屏幕”组件,为每一屏分配路由地址:

//App.js
<NavigationContainer>		导航容器(类似于之前的路由器)
	<Navigator>			导航器(类似于之前的路由列表)
		<Screen name="login" component={ Login }/>		屏幕(类似于之前的路由对象)
		......
		<Screen name="list" component={ List }/>		屏幕(类似于之前的路由对象)
	</Navigator>
</NavigationContainer>

⑤如何定制标题栏?
方法1:静态配置法(App.js里)

<Screen name component options={{title, headerStyle, headerTintColor,...}}/>

方法2:动态修改法(路由组件里)

props.navigation.setOptions({title, headerStyle, headerTintColor,...})

⑥如何在页面/屏幕间跳转?

props.navigation.navigate(目标地址)   //导航跳转	
	props.navigation.goBack()			//导航返回
	------------------------------------------------------------------------------
	props.navigation.push(目标地址)		//新页面入历史栈
	props.navigation.pop()				//当前页面从历史栈中弹出,返回上一页面
	props.navigation.popToTop()			//所有页面从历史栈中弹出,返回第一个页面,常用于退出登录

⑦如何在跳转时携带路由参数?
页面1:props.navigation.navigate(目标地址, {k1: v1, k2:v2, ....} )
页面2:props.route中可以读取上个页面传来的路由参数
提示:RN的路由跳转传参没有采用类似浏览器应用中的“查询字符串”方案——?k=v&k=v&…
查询字符串格式来自于HTTP协议,专用于浏览器的传参方案 —— RN应用没有浏览器

七、React父子组件间的数据传递

父组件=>子组件 —— Props Down:

//Parent.js
let [carousels] = useState([(),(),...])
<Child list={carousels}/>	

//Child.js
function Child( { list } ){
   return <>{list.map(...)}</>
}

子组件=>父组件 —— Props Up:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/116110.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

从业多年的Android开发,竟拿不到 Application Context?

Android 开发者们对于 Application 并不陌生。有的时候为避免内存泄漏&#xff0c;常常不直接使用 Context 而是通过其提供的 getApplicationContext() 确保拿到的是 Application 级别的 Context。而本次像通常一样&#xff0c;拿到的 Application 却是 null&#xff0c;到底是…

国考省考行测:细节理解,对错判断,要素查找,问什么,找什么,对比分析

国考省考行测&#xff1a;细节理解&#xff0c;对错判断&#xff0c;要素查找&#xff0c;问什么&#xff0c;找什么&#xff0c;对比分析 2022找工作是学历、能力和运气的超强结合体! 公务员特招重点就是专业技能&#xff0c;附带行测和申论&#xff0c;而常规国考省考最重要…

头戴式耳机适合运动吗、五款最适合运动的耳机分享

戴着耳机锻炼&#xff0c;听着动感的音乐&#xff0c;会让你心潮澎湃&#xff0c;瞬间感觉自己力大无穷。那什么样的耳机更适合在健身房锻炼时戴呢&#xff1f;首先稳固性和舒适度一定要比较好&#xff0c;毕竟在运动的过程中老是感觉到不适或者掉落&#xff0c;那真的是很令人…

旋转的扰动、导数和积分

The plus operator 设M\mathcal{M}M表示一个n维的流型&#xff0c;因为流型局部同胚与Rn\mathbb{R}^nRn&#xff0c;所以我们可以通过定义符号⊞\boxplus⊞和⊟\boxminus⊟建立一个流型M\mathcal{M}M的局部邻域和其正切空间的双射。 ⊞:MRn→M;⊟:MMn→Rn\boxplus:\mathcal{M}…

为什么说用了MES系统,但生产数字化管理只做到20%?

随着越来越多的制造企业开始体验和建设MES系统&#xff0c;MES系统能够实现生产执行过程的有效数字化管理已经成为共识。回过头来看&#xff0c;是不是只有生产进度才是工厂需要管理的&#xff1f;当你想详细了解当前存在的问题&#xff0c;进展如何&#xff0c;哪些月度重点任…

JAVA零基础小白学习教程之day09-内部类权限final静态

day09-JAVAOOP 课程目标 1. 【理解】什么是内部类 2. 【掌握】匿名内部类 3. 【掌握】引用数据类型作为方法的参数 4. 【理解】final关键字的使用 5. 【理解】包的定义及使用 6. 【理解】权限修饰符 7. 【掌握】static关键字的使用B友https://www.bilibili.com/video/BV1QG4y…

职场员工有没有潜力,看这一个能力就够了

在我组织的研讨会上&#xff0c;讲故事的课程通常以一个思考练习开始。 我会让参与者闭上眼睛回忆《小红帽》的故事&#xff0c;尤其考虑其中的情节、起伏和结尾。这个练习有时会引发一阵笑声&#xff0c;人们会好奇这与课程有什么相关性&#xff0c;或者干脆把《小红帽》与《…

给Debezium connector 发送信号

1. 概述 Debezium 信号机制提供了一种方法来修改连接器的行为&#xff0c;或触发一次性操作&#xff0c;例如启动表的 临时快照。要触发连接器执行指定操作&#xff0c;可以发出特殊的SQL 命令以将信号消息添加到专门的信号表&#xff0c;也称为信号数据集合。在源数据库上创建…

哪些进销存软件既好用又免费?

中小企业刚起步都会面临着资金紧缺、人力资源不足等诸多管理问题&#xff0c;对于大部分预算不是很多的中小企业或者尚未尝试过进销存软件的企业&#xff0c;都会选择免费进销存软件来进行企业管理或体验进销存软件的功效。 进销存软件的开发需要强大的技术支持&#xff0c;数…

B站技术选型与架构

目录前言B站前端之路B站Golang技术栈分析bilibili技术总监毛剑简介前言 了解了一下B站的技术发展历程&#xff1a;最开始是用PHP语言开发的&#xff0c;后来B站的中台逐步被Node占领&#xff0c;而后台技术为了更高的并发、更稳健&#xff0c;以及为了大数据分析&#xff0c;逐…

RK3568平台开发系列讲解(Linux系统篇)共享内存

🚀返回专栏总目录 文章目录 一、共享内存底层实现二、共享内存API三、共享内存案例沉淀、分享、成长,让自己和他人都能有所收获!😄 📢共享内存技术是功能最强、应用最广的进程间通信技术。其原理是多个进程共享相同的物理内存区,一个进程对该内存区的任意修改,可被其…

不懂Nacos没关系,可以看看它是怎么运用代理模式的

背景 看Nacos的源代码时&#xff0c;发现其中有对代理模式的运用&#xff0c;而且用得还不错&#xff0c;可以作为一个典型案例来聊聊&#xff0c;方便大家以更真实的案例来体验一下代理模式的运用。如果你对Nacos不了解&#xff0c;也并不影响对本篇文章的阅读和学习。 本文…

前端三小时用html和js写一个贪吃蛇游戏,非常简单带讲解,代码可直接用,功能完整

目录 游戏主体部分--地狱模式 游戏主页入口 预览图 游戏入口代码 1.html 2.css 3.js 注册页面代码 游戏实现很简单&#xff0c;只写游戏主体的话只要三小时就够了。 话不多说&#xff0c;我们直接来看效果预览。 转成gif图之后有点卡&#xff0c;但是游戏效果并不卡&…

php宝塔搭建部署实战PESCMSTEAM团队任务管理系统源码

大家好啊&#xff0c;我是测评君&#xff0c;欢迎来到web测评。 本期给大家带来一套php开发的PESCMSTEAM团队任务管理系统源码&#xff0c;感兴趣的朋友可以自行下载学习。 技术架构 PHP7.2 nginx mysql5.7 JS CSS HTMLcnetos7以上 宝塔面板 文字搭建教程 下载源码&am…

k8s lifecycle——poststart和prestop

1、lifecycle的声明 lifecycle:postStart:exec:command: ["/bin/sh", "-c", "sleep 100"]preStop:exec:command: ["/bin/sh", "-c", "sleep 100"]2、poststart 容器创建后立即执行&#xff0c;主要用于资源部署、…

JPEG编码原理及简易编码器实现

简介 以学习为目的编写的简易jpeg编码器&#xff0c;以看得懂为目标&#xff0c;代码尽可能清晰简洁&#xff0c;不对内存、性能做看不懂的优化&#xff0c;也不实现jpeg更多高级特性。 这篇文章是我从自己的开源工程中整理来的 本文对应的工程为https://gitee.com/dma/learn…

【OpenFOAM】-olaFlow-算例4- irreg45degTank

算例路径&#xff1a; olaFlow\tutorials\irreg45degTank 算例描述&#xff1a; 不规则波浪模拟 学习目标&#xff1a; 不规则波浪模拟&#xff1a;olaFlow中单向不规则波采用线性波浪叠加法生成&#xff0c;基本原理如图2所受&#xff0c;需要提供对应波谱的周期、波高和相位的…

生产制造业管理系统对企业究竟有哪些作用?

对于生产制造企业来说&#xff0c;除了涉及到产品的生产制造和原料采购&#xff0c;还需要管理销售、库存、财务等方方面面&#xff0c;生产制造业管理系统的使用&#xff0c;尤为重要。正因如此&#xff0c;借助生产制造业管理系统来完善生产管理流程、提升生产管理水平&#…

LVGL学习笔记4 - 主题Themes

目录 1. 获取主题句柄 2. 设置基础主题 3. 设置主题的回调函数 4. 使能主题 5. 实例 5.1 定义一个全局Style变量 5.2 显示默认主题风格的矩形 5.3 初始化新主题的样式 5.4 初始化新主题 5.5 回调函数的实现 5.6 设置新主题 5.7 显示 主题是风格的集合。对应的变量结构…

设计模式--reactor 模式

说明 本文基于 tomcat 8.5.x 编写。author blog.jellyfishmix.com / JellyfishMIX - githubLICENSE GPL-2.0 介绍 reactor 模式通常应用于网络 IO 场景&#xff0c;高性能的中间件 redis, netty 都在使用。 背景 原始的网络 IO 模型 最原始的网络 IO 模型&#xff0c;服务…