在我的第一个应用程序上使用React Antial的挑战
#javascript #reactnative #android #ios

最初的挑战

设置环境变量,例如Java,Kotlin,Android E Android SDK,以及Android Studio程序以及配置某些模拟器,可能是最初的挑战。通过所有初始设置进行所有操作系统可能会略有不同。就我而言,我使用了Linux,花了大量时间。

Photo by [Simon Abrams](https://unsplash.com/@flysi3000?utm_source=medium&utm_medium=referral) on [Unsplash](https://unsplash.com?utm_source=medium&utm_medium=referral)

错误分辨率

可以在整个项目中确定一些技术挑战,例如:

代码:删除未使用的代码和功能和钩子的重复使用不当;

复杂性:代码中功能和责任的分离和重组;

样式:改善布局响应能力,例如字体大小和新布局的创建。一个建议是使用React Abtic的dimensions,这将极大地促进该过程;

库:更新库,这在JavaScript项目中是一个常见的问题,尤其是在较旧的项目中,可能会出现几种不兼容。

例外处理:每个应用程序都必须具有例外处理,以避免应用程序使用中的损坏。一种选择是使用 react-native-exception-handler 库,该库有助于处理致命或无致命的例外,从而可以在可以显示的错误编目中进行更高的自定义。

TypeScript: 一个项目可能会带来一些挑战,但是您的桌子上出现了充满可能性的新场景,例如优化,改进,最佳实践和新图书馆,所有这些都可以为最佳的应用程序提供最佳的应用程序最终用户。

在本文中,我分享了我的主要挑战,我认为这对于移动区域的所有初学者开发人员都是普遍的。因此,我希望能够贡献一些有用的知识。如果您经历了类似的情况或喜欢我分享的内容,请分享并喜欢文章!

添加此工具对于有助于确保代码质量并减少数据处理中的常见错误至关重要,从而增加了开发过程中错误检测的可能性。

面对性能问题:记忆

这个话题确实是最具挑战性的话题之一。了解该应用程序意外关闭的原因,提出了几个问题:

可能是代码错误,有些变量为null或未定义并导致映射(MAP)操作?
该应用程序是否由于在同一屏幕上渲染过多的数据而陷入困境?
可能是内存泄漏吗?

与此相关的问题通常涉及内存泄漏。在此阶段,对React Nation的记忆管理进行彻底研究至关重要。我建议阅读本文: Hunting JS memory leaks in React Native apps

但是,初始解决方案通常涉及细致的代码搜索。重构组件具有较高的数据流和复杂性以使用最佳性能实践,例如:

钩子: usememo,usecallback e useeffect;

api:懒惰,备忘录flatlist, contextAPI ;

;

考虑到每个工具的目标,必须负责任地完成这些工具的使用。

解决潜在错误的其他技巧包括删除具有条件限制的不必要的组件渲染,例如数据分页。此外,必须避免将不正确的属性传递给这些组件。

为了渲染各种项目,在数据搜索中使用flatlist和分页策略对于防止数据检索引起冻结至关重要。请记住,在移动设备中,数据负载限制应比网络环境中通常使用的限制更轻。

奖金

版本控制

我遇到的常见问题之一是在Android和iOS上处理更新检查。当用户不经常更新应用程序时,这将成为一个挑战。一种策略是克服此问题,就是迫使用户通过各自的应用商店更新应用程序。为此,您可以使用react-native-version-check库,该库将检查已安装的应用程序的版本,并将其与商店中可用的版本进行比较。这样,如果有更新,您可以显示信息丰富的弹出窗口。

WebView

React Native具有一个有用的库来合并WebView策略,使您可以在应用程序本身中显示网页。但是,这种方法有其局限性,尤其是在处理具有强烈数据流的网页时。

要克服这个问题,我建议一个绝佳的选择:react-native-inappbrowser-reborn库。有了它,您将体验更流畅的性能,并能够自定义网页的显示。此外,此库允许您在默认浏览器中打开页面或与任何其他应用程序共享链接,从而在应用程序中提供更大的灵活性和与Web的互动,而无需限制标准WebView。

最后的想法

一个项目可能会带来一些挑战,但是您的桌子上出现了一个充满可能性的新场景,例如优化,改进,最佳实践和新图书馆,所有这些都可以将最佳应用程序交付给最终用户。

在本文中,我分享了我的主要挑战,我认为这对于移动区域的所有初学者开发人员都是普遍的。因此,我希望能够贡献一些有用的知识。如果您经历了类似的情况或喜欢我分享的内容,请 share 喜欢文章!