React DAY06

news2025/1/11 23:58:54

复习:

1.React是一个用于构建用户界面的JS库——不涉及HTML/CSS。可用于创建PC网站、H5、WebApp、NativeApp。2013年中Facebook开源,目前最新版V18.2。
主要知识点:
使用React的两种方法:脚本引入式、脚手架方式(create-react-app)
JSX:是React借鉴的TS语法,本质是React.createElement()
数据绑定:七种绑定——{ 表达式 }
两种自定义组件方式:class组件、函数式组件
属性和状态class——this.props/state&setState()、function——形参props/useState()
生命周期方法class——挂载(3)/更新(3)/卸载(1)、function——useEffect()
HooksuseState()/useEffect()/useRef()/useContext()
2.React Native是一个基于React框架的UI组件库——不允许出现HTML/CSS,专用于创建NativeApp,由Facebook开源,目前最新版V0.70。
主要知识点:
①样式和布局:行内样式/内部样式(StyleSheet)/外部样式(style.js)——样式都是对象; display:flex/none;
②常用组件和API:View、Text、Image、TextInput、Button、...
③异步请求:fetch
④路由和导航:React-Navigation

基于浏览器的React项目使用的路由导航模块:react-router-dom
脱离浏览器的React项目(即RN项目)使用的路由导航模块:react-navigation

一、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:触摸后不透明度可以改变的组件,为其它组件提供用户交互反馈

四、RN中常用的JS API

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

总结:客户端缓存汇总
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="" component={ }/>		屏幕(类似于之前的路由对象)
		......
		<Screen name="" component={ }/>		屏幕(类似于之前的路由对象)
	</Navigator>
</NavigationContainer>

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

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

相关文章

VUE部署至Nginx

VUE部署至Nginx安装Nginx解压Nginx配置VUE文件配置Nginx启动Nginx快速停止或关闭nginx正常停止或关闭nginx配置文件nginx.conf修改重装载命令安装Nginx 网址&#xff1a;https://nginx.org/en/download.html 选择图中红框下载安装 解压Nginx 只需要解压到目录&#xff0c;无…

GitHub典藏版,腾讯T14级高级程序员亲码的分布式数据库实践,再次爆火

数据库就是要做好五件事&#xff0c;存储、事务、查询、复制和其他。而对分布式数据库来说&#xff0c;不仅要继续做这五件事&#xff0c;还要多出一件事&#xff0c;分片。在这六件事中&#xff0c;存储和其他这两件事与单体数据库差不多&#xff0c;难点就在事务、查询、复制…

论文复现丨基于ModelArts进行图像风格化绘画

摘要&#xff1a;这个 notebook 基于论文「Stylized Neural Painting, arXiv:2011.08114.」提供了最基本的「图片生成绘画」变换的可复现例子。本文分享自华为云社区《基于ModelArts进行图像风格化绘画》&#xff0c;作者&#xff1a; HWCloudAI 。 项目首页 | GitHub | 论文 …

敏捷、分散式的数据治理,该如何实现?

01 数据资产的生产和消费现状 —— 孤岛就在那里&#xff01; 在大数据时代&#xff0c;企业数据资产的生产和消费&#xff0c;实际现状大概是这样的。 一方面&#xff0c;每个业务部门都产生并存储了大量的数据。这些数据存储在不同的系统中。每个业务部门都是数据的生产者…

安卓逆向-某音乐软件

初学安卓逆向&#xff0c;如有错误请指教 某我音乐9.3.4.4版本&#xff0c;需要资源的请流言&#xff08;也可以自行去下载&#xff09; 直接将apk拖入到AndroidKiller里面(该工具自行下载) 首先去除广告 直接全局搜索KEY_EXTRA_AUTH&#xff0c;可以只在.smali文件里面搜索…

【gitlab wiki】git首次上传本地文档操作步骤

1.在gitLab中创建一个项目 2.进入本地电脑中的你要上传文件的文件目录&#xff0c;右击鼠标选择“ Git Bash Here” git命令窗口(本机电脑要安装好git) 3.在远程git项目中&#xff0c;复制出项目http地址。 4.在“ Git Bash Here” git命令窗口输入命令&#xff1a;git clone h…

Java+MYSQL基于ssm的网上出差审批与费用报销管理系统

全新的时代,新的技术推动着公司管理制度的改革,在管理层面加入了先进的科学技术做到了与时俱进,所以企业创建自己的网上出差审批与费用报销系统是迫切需要的。在新时代的背景下,传统管理方式的缺点被暴露出来,传统管理方式的不足的地方有管理及时性不够,下达一个指令以后需要层…

AuthLab权限在线靶场通关记录

AuthLab通关记录 一个在线的权限靶场&#xff1a;https://authlab.digi.ninja/ 靶场内容比较简单&#xff0c;包括了JWT以及一些基本情况的权限Bypass IP Based Auth Bypass 该关卡根据提示有一个ip在192.168.0.100-200范围里可以直接bypass 拦截请求包修改X-Forwarded-For爆…

python网络副业有哪些?以自身经历分享怎么做副业挣钱

网络副业我个人比较看好的是Python&#xff0c;至少我是真实体会到了Python做副业真香&#xff0c;疫情被关在家那段时间也没耽误赚钱&#xff0c;反而比平常赚的还多一点&#xff0c;下图是我疫情期间在家做Python副业收入的部分截图&#xff0c;那会儿我用Excel表格每天记了一…

BEPU物理引擎碰撞系统的架构与设计

前面我们讲解了如何监听物理引擎的碰撞事件, 在物理引擎内核中如何架构与设计碰撞规则,使得物理Entity与周围的物理环境产生碰撞时&#xff0c;如何灵活的控制物理碰撞&#xff0c;本节給大家详细的讲解BEPUphysicsint 物理引擎内部是如何管理与控制碰撞规则的。本文主要讲解3个…

彻底删除的文件如何恢复?误删数据恢复,四种方法就可以解决

电脑磁盘中存储了许多文件&#xff0c;我们不可避免地会误删一些文件&#xff0c;但是我们中的许多人不知道在文件被错误删除后如何恢复它们。事实上&#xff0c;误删数据恢复没有想象中那么难&#xff0c;我们自己也可以操作完成。到底是什么方法&#xff1f;接下来我们将详细…

Java项目:springboot中小医院信息管理系统

作者主页&#xff1a;源码空间站2022 简介&#xff1a;Java领域优质创作者、Java项目、学习资料、技术互助 文末获取源码 项目介绍 1. 基于SpringBoot的中小医院信息管理系统&#xff0c;实现了部分核心功能。 2. 就诊卡提供了手动和读卡两种方式录入&#xff0c;其中IC读卡器…

Simulink 自动代码生成电机控制:基于霍尔FOC模型和代码生成

目录 霍尔角度估算原理 霍尔角度估算FOC模型和仿真 代码生成软件调试 总结 霍尔角度估算原理 PMSM在定子侧以互差120电角度的位置安装3个霍尔元件Ha, Hb, Hc。当转子转动时&#xff0c;霍尔元件会产生3个相位差120电角度的高低电平信号。霍尔信号会将一个电周期划分为6个扇…

可以快速搭建的免费开源项目:直播带货、富文本笔记、思维导图、声音克隆、消息推送服务、文档协作等等

可以快速搭建的免费开源项目&#xff1a;直播带货、富文本笔记、思维导图、声音克隆、消息推送服务、文档协作等等。 01 Pure Live 一个想让直播回归纯粹的项目&#xff0c;没有礼物、粉丝团、弹窗&#xff0c;只有直播和弹幕。这是国人在GitHub上制作的一个开源的直播系统&am…

一个转行者的自述,大学生做职业规划要趁早

这篇文章写给对自己的职业规划不清晰、想从第一份工作就找准职业方向的应届大学生。 作为21年毕业的职场新人&#xff0c;算不上建议&#xff0c;也不写鸡汤&#xff0c;只是在这里认真分享我走过的弯路。文章略长&#xff0c;预计阅读时间8分钟。 先说一个关于海的小故事 人们…

CSS -- CSS使用过渡(transition)添加动画

CSS 3过渡 过渡&#xff08;transition)是CSS3中具有颠覆性的特征之一&#xff0c;我们可以在不使用 Flash 动画或JavaScript 的情况下&#xff0c;当元素从一种样式变换为另一种样式时为元素添加效果。 过渡动画&#xff1a; 是从一个状态 渐渐的过渡到另外一个状态 可以让…

js什么是闭包?简单理解

闭包 作用域链和执行上下文 理解闭包前&#xff0c;先引入一个概念&#xff0c;作用域链 用我自己理解的讲&#xff1a;在一段程序中&#xff0c;程序内的变量、函数等都被串在这条链上&#xff0c;当我们使用这些变量、函数时&#xff0c;程序就会在这条链中搜索&#xff0…

【最新】滤器完整性检测各国规定

中国 用于直接接触无菌药液或无菌设备表面的气体的过滤器&#xff0c;应在每批或多批次连续生产结束后对其进行完整性测试。对于其他的应用&#xff0c;可以根据风险评估的结果&#xff0c;制定完整性测试的频率。 ——除菌过滤技术与应用指南 2018 美国 We recommend that …

系统中的安全架构

系统中的安全架构目录概述需求&#xff1a;设计思路实现思路分析1.shiro2.多模块下的安全架构参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a better result,wait for chan…

【网安神器篇】——searchsploit漏洞利用搜索工具

作者名&#xff1a;Demo不是emo 主页面链接&#xff1a;主页传送门 创作初心&#xff1a;舞台再大&#xff0c;你不上台&#xff0c;永远是观众&#xff0c;没人会关心你努不努力&#xff0c;摔的痛不痛&#xff0c;他们只会看你最后站在什么位置&#xff0c;然后羡慕或鄙夷座…