React Native 最佳实践
来源:dev.to
时间:2024-11-15 15:54:37 485浏览 收藏
一分耕耘,一分收获!既然打开了这篇文章《React Native 最佳实践》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!
如果您是 react native 开发者初学者,或者有经验,那么您必须意识到代码实践是一项不容妥协的技能。作为开发人员,项目的交付是必须的,但编写可扩展且高质量的代码将对您和您的团队的未来有所帮助。
在我们继续之前,这些实践可以在 react native cli 或 expo 项目上使用。从 2024 年开始,rn 团队表示,expo 将成为构建 react native 项目的官方框架。
在这篇博客中,我们将学习 react native 项目的代码实践。请记住,一个好的项目是以下方面的平衡:
可扩展
一致性
可维护
可读性
阅读我的博客,了解如何作为 reactjs 开发人员开始使用 react native 开发人员
1、项目结构
开发人员的首要任务是拥有可维护、可读且可扩展的代码库。您的项目结构也将对未来的开发人员有所帮助。有了 expo,人们就有了项目的结构,但作为一名 react native 开发者,你应该根据你的项目来规划你的项目结构:
my-app/ ├── assets/ │ ├── fonts/ │ ├── images/ │ └── icons/ ├── components/ │ ├── button.js │ ├── button.styles.js │ └── header.js ├── screens/ │ ├── homescreen/ │ │ ├── homescreen.js │ │ └── homescreen.styles.js │ └── profilescreen/ │ ├── profilescreen.js │ └── profilescreen.styles.js ├── navigation/ │ ├── appnavigator.js │ ├── authnavigator.js │ └── mainnavigator.js ├── redux/ (or store/ if using zustand, mobx, etc.) │ ├── actions/ │ ├── reducers/ │ ├── store.js │ └── types.js ├── services/ │ ├── api.js │ └── auth.js ├── utils/ │ ├── helpers.js │ └── constants.js ├── app.js ├── package.json ├── .babelrc └── readme.md
2.导入别名
长导入路径会使您的代码更难以阅读和维护。不要编写像 ../../../components/button 这样的长相对路径,而是使用别名来缩短它们并使代码更具可读性。
import button from 'components/ui/button'; import header from 'components/layout/header';
3.进口订单
要自动管理导入的顺序,您可以使用一个为您处理此问题的插件来配置 babel。这可以保持您的导入清洁并减少人工干预。
npm install --save-dev babel-plugin-module-resolver
4.打字稿
在 typescript (ts) 和 javascript (js) 之间进行选择时几乎没有争议,特别是对于大型应用程序。 typescript 提供静态类型检查,有助于在编译时而不是运行时捕获错误,从而生成更可靠和可维护的代码。
5. 风格
可以通过多种方式设计 rn 项目。可以使用 nativewind 或 react native 的样式。面对如此多的选择,我们应该追求一致性、可扩展性和可维护性。在这里阅读我关于造型的博客
1。内联:对于大型项目来说根本不是一个好方法。
<view style={{ backgroundcolor: 'blue', padding: 10 }}> <text style={{ color: 'white' }}>hello</text> </view>
2。 stylesheet api: 很好,但是样式不能重用
import { stylesheet, view, text } from 'react-native'; const styles = stylesheet.create({ container: { backgroundcolor: 'blue', padding: 10, }, text: { color: 'white', }, }); const app = () => ( <view style={styles.container}> <text style={styles.text}>hello</text> </view> );
3。单独的样式:这是我在大型项目中更喜欢的样式方式。创建一个单独的 style.js 并在您需要的组件中使用它。
/components ├── mycomponent.js ├── mycomponent.styles.js /app.js
// mycomponent.styles.js import { stylesheet } from 'react-native'; export default stylesheet.create({ container: { flex: 1, justifycontent: 'center', alignitems: 'center', backgroundcolor: '#f5f5f5', }, title: { fontsize: 24, fontweight: 'bold', color: '#333', marginbottom: 20, }, button: { backgroundcolor: '#007bff', paddingvertical: 10, paddinghorizontal: 20, borderradius: 5, }, buttontext: { color: '#fff', fontsize: 16, fontweight: '600', }, });
// mycomponent.js import react from 'react'; import { view, text, pressable } from 'react-native'; import styles from './mycomponent.styles'; const mycomponent = () => { return ( <view style={styles.container}> <text style={styles.title}>hello from mycomponent</text> <pressable style={styles.button}> <text style={styles.buttontext}>click me</text> </pressable> </view> ); }; export default mycomponent;
4。样式化组件:大型项目的另一种首选方式。
import styled from 'styled-components/native'; const container = styled.view` background-color: blue; padding: 10px; `; const styledtext = styled.text` color: white; `; const app = () => ( <container> <styledtext>hello</styledtext> </container> );
5。原生风: nativewind 是设计应用程序风格的好方法。安装原生 wind 后,您可以使用这些类来设计您的应用程序。这样您就可以委托造型工作。
import react from 'react'; import { view, text, pressable } from 'react-native'; import { styled } from 'nativewind'; const app = () => { return ( <view classname="flex-1 justify-center items-center bg-gray-100"> <text classname="text-2xl font-bold text-blue-500 mb-4"> welcome to nativewind! </text> <pressable classname="bg-blue-500 px-4 py-2 rounded"> <text classname="text-white font-semibold">press me</text> </pressable> </view> ); }; export default app;
6.道具
props 用于 react native 中组件之间的通信,允许数据从父组件流向子组件。就像样式一样,管理道具的方法也有多种。一致性是关键,因此建议在整个项目中坚持使用一种方法。
此外,始终解构 props 以获得更清晰、更易读的代码。解构不仅提高了可读性,还可以更轻松地发现组件正在使用哪些 props。
const mycomponent = ({ title, subtitle }) => { return ( <view> <text>{title}</text> <text>{subtitle}</text> </view> ); };
7. 状态管理
高效的状态管理可确保应用程序随着代码库的增长而保持高性能和可管理性。如今,我们有很多选择来选择最好的状态管理人员。
a.更喜欢本地状态而不是全局状态
b.使用 context api 实现简单状态
c.使用状态管理库处理复杂状态
d.不可变状态更新
e.更喜欢 redux 工具包而不是 redux
import { createslice } from '@reduxjs/toolkit'; const booksslice = createslice({ name: 'books', initialstate: [], reducers: { addbook: (state, action) => { state.push(action.payload); }, removebook: (state, action) => { return state.filter(book => book.id !== action.payload); }, }, }); export const { addbook, removebook } = booksslice.actions; export default booksslice.reducer;
8. 崩溃分析
为了确保应用程序的健康并减少崩溃,实施崩溃分析和错误跟踪非常重要:
a。使用崩溃分析工具:实施 firebase crashlytics 或 sentry
等服务b。测试您的应用程序的稳定性
运行自动化测试和手动压力测试以捕获边缘情况崩溃。利用 testflight 或 google play beta 测试等服务。
您可以跟踪本机崩溃(ios/android)和 javascript 错误。使用 errorboundary 捕获 javascript 错误并将其记录到崩溃分析服务。
c.跟踪 js 和本机错误
import react from 'react'; import * as sentry from '@sentry/react-native'; class errorboundary extends react.component { componentdidcatch(error, errorinfo) { sentry.captureexception(error, { extra: errorinfo }); } render() { if (this.state.haserror) { return <text>something went wrong.</text>; } return this.props.children; } }
9. 日志记录
日志记录有助于跟踪应用行为、调试问题和收集分析。
a。使用日志框架
react native logger:专为 react native 设计的易于使用的记录器。
winston:一个可以与 react native 和 node.js 一起使用的多传输日志库。
import logger from 'react-native-logger'; logger.log('This is a debug log'); logger.warn('This is a warning log'); logger.error('This is an error log');
b。区分日志级别
使用适当的日志级别,例如调试、信息、警告和错误。
在生产中,通过仅允许错误和警告日志来最大程度地减少日志记录的冗长性,而在开发模式下,请使用调试和信息。
c.远程记录
考虑将日志发送到远程日志服务,例如:
纸迹
洛格利
firebase analytics
d.仔细记录敏感信息
避免记录敏感的用户信息,例如密码、令牌或个人数据。
10. 测试
每个项目的测试都至关重要。作为开发商,质量是开发商的责任。在 react native 世界里有:
单元测试
集成测试
端到端测试
至少要花时间进行端到端测试。有很多工具可用于测试。
快乐学习!!
好了,本文到此结束,带大家了解了《React Native 最佳实践》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
262 收藏
-
349 收藏
-
438 收藏
-
339 收藏
-
224 收藏
-
171 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习