当前位置:首页 > 文章列表 > 文章 > 前端 > React Native 最佳实践

React Native 最佳实践

来源:dev.to 2024-11-15 15:54:37 0浏览 收藏

一分耕耘,一分收获!既然打开了这篇文章《React Native 最佳实践》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!

React Native 最佳实践

如果您是 react native 开发者初学者,或者有经验,那么您必须意识到代码实践是一项不容妥协的技能。作为开发人员,项目的交付是必须的,但编写可扩展且高质量的代码将对您和您的团队的未来有所帮助。

在我们继续之前,这些实践可以在 react native cli 或 expo 项目上使用。从 2024 年开始,rn 团队表示,expo 将成为构建 react native 项目的官方框架。

在这篇博客中,我们将学习 react native 项目的代码实践。请记住,一个好的项目是以下方面的平衡:

  1. 可扩展

  2. 一致性

  3. 可维护

  4. 可读性

阅读我的博客,了解如何作为 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。内联:对于大型项目来说根本不是一个好方法。


  hello

2。 stylesheet api: 很好,但是样式不能重用

import { stylesheet, view, text } from 'react-native';

const styles = stylesheet.create({
  container: {
    backgroundcolor: 'blue',
    padding: 10,
  },
  text: {
    color: 'white',
  },
});

const app = () => (
  
    hello
  
);

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 (
    
      hello from mycomponent
      
        click me
      
    
  );
};

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 = () => (
  
    hello
  
);

5。原生风: nativewind 是设计应用程序风格的好方法。安装原生 wind 后,您可以使用这些类来设计您的应用程序。这样您就可以委托造型工作。

import react from 'react';
import { view, text, pressable } from 'react-native';
import { styled } from 'nativewind';

const app = () => {
  return (
    
      
        welcome to nativewind!
      
      
        press me
      
    
  );
};

export default app;

6.道具

props 用于 react native 中组件之间的通信,允许数据从父组件流向子组件。就像样式一样,管理道具的方法也有多种。一致性是关键,因此建议在整个项目中坚持使用一种方法。

此外,始终解构 props 以获得更清晰、更易读的代码。解构不仅提高了可读性,还可以更轻松地发现组件正在使用哪些 props。

const mycomponent = ({ title, subtitle }) => {
  return (
    
      {title}
      {subtitle}
    
  );
};

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 something went wrong.;
    }

    return this.props.children;
  }
}

9. 日志记录

日志记录有助于跟踪应用行为、调试问题和收集分析。

a。使用日志框架

  1. react native logger:专为 react native 设计的易于使用的记录器。

  2. 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。区分日志级别

  1. 使用适当的日志级别,例如调试、信息、警告和错误。

  2. 在生产中,通过仅允许错误和警告日志来最大程度地减少日志记录的冗长性,而在开发模式下,请使用调试和信息。

c.远程记录

考虑将日志发送到远程日志服务,例如:

  1. 纸迹

  2. 洛格利

  3. firebase analytics

d.仔细记录敏感信息

避免记录敏感的用户信息,例如密码、令牌或个人数据。

10. 测试

每个项目的测试都至关重要。作为开发商,质量是开发商的责任。在 react native 世界里有:

  1. 单元测试

  2. 集成测试

  3. 端到端测试

至少要花时间进行端到端测试。有很多工具可用于测试。

快乐学习!!

好了,本文到此结束,带大家了解了《React Native 最佳实践》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
苹果电脑系统没有了苹果电脑系统没有了
上一篇
苹果电脑系统没有了
怎么看电脑支不支持Win11 电脑不支持Win11怎么办
下一篇
怎么看电脑支不支持Win11 电脑不支持Win11怎么办
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI Make Song:零门槛AI音乐创作平台,助你轻松制作个性化音乐
    AI Make Song
    AI Make Song是一款革命性的AI音乐生成平台,提供文本和歌词转音乐的双模式输入,支持多语言及商业友好版权体系。无论你是音乐爱好者、内容创作者还是广告从业者,都能在这里实现“用文字创造音乐”的梦想。平台已生成超百万首原创音乐,覆盖全球20个国家,用户满意度高达95%。
    22次使用
  • SongGenerator.io:零门槛AI音乐生成器,快速创作高质量音乐
    SongGenerator
    探索SongGenerator.io,零门槛、全免费的AI音乐生成器。无需注册,通过简单文本输入即可生成多风格音乐,适用于内容创作者、音乐爱好者和教育工作者。日均生成量超10万次,全球50国家用户信赖。
    18次使用
  •  BeArt AI换脸:免费在线工具,轻松实现照片、视频、GIF换脸
    BeArt AI换脸
    探索BeArt AI换脸工具,免费在线使用,无需下载软件,即可对照片、视频和GIF进行高质量换脸。体验快速、流畅、无水印的换脸效果,适用于娱乐创作、影视制作、广告营销等多种场景。
    18次使用
  • SEO标题协启动:AI驱动的智能对话与内容生成平台 - 提升创作效率
    协启动
    SEO摘要协启动(XieQiDong Chatbot)是由深圳协启动传媒有限公司运营的AI智能服务平台,提供多模型支持的对话服务、文档处理和图像生成工具,旨在提升用户内容创作与信息处理效率。平台支持订阅制付费,适合个人及企业用户,满足日常聊天、文案生成、学习辅助等需求。
    20次使用
  • Brev AI:零注册门槛的全功能免费AI音乐创作平台
    Brev AI
    探索Brev AI,一个无需注册即可免费使用的AI音乐创作平台,提供多功能工具如音乐生成、去人声、歌词创作等,适用于内容创作、商业配乐和个人创作,满足您的音乐需求。
    22次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码