构建了我的第一个React Native应用程序之后,我现在确信这是未来。

by Taylor Milliman

泰勒·米利曼(Taylor Milliman)

构建了我的第一个React Native应用程序之后,我现在确信这是未来。 (After building my first React Native app, I’m now convinced it’s the future.)

After a few weeks of playing around with React Native, I just came away with my first real mobile app. It’s fairly simple, but it only took me a few days to build and I had a blast doing it.

在使用React Native玩了几周之后,我才有了第一个真正的移动应用程序。 这很简单,但是我只花了几天的时间就完成了开发工作。

I created a mobile app for my favorite food blog, Smitten Kitchen.

我为我最喜欢的美食博客Smitten Kitchen创建了一个移动应用程序。

The app allows users to search through a database of over 1,000 recipes, and concisely view the necessary ingredients and directions for each one.

该应用程序允许用户搜索包含1000多个食谱的数据库,并简洁地查看每个食谱的必要成分和说明。

Users can also bookmark recipes and easily share them with a friend.

用户还可以为食谱添加书签,并轻松与朋友分享。

I’m still waiting for permission from the blog to publish this app, but you can check out all of the code here. Note that the url for my API has been stubbed for the time being out of respect for Smitten Kitchen.

我仍在等待博客的许可以发布此应用,但是您可以在此处查看所有代码。 请注意,出于对Smitten Kitchen的尊重,我的API的网址已被暂时删除。

React Native不会很快消失 (React Native isn’t going away any time soon)

A common reservation among developers is that they don’t want to invest the time to learn a new technology if there’s a strong chance it will become obsolete in the near future.

开发人员的共同保留意见是,如果有很大的机会在不久的将来过时,他们就不想花时间学习新技术。

Even from my relatively minimal experience with React Native, I’ve found it to be an enormously powerful tool. I am confident it will be used in the years to come.

即使从相对最少的React Native经验中,我也发现它是一个非常强大的工具。 我相信它将在未来几年中使用。

Facebook, Instagram, and Airbnb all built the latest versions of their mobile apps using React Native. And here’s a list of the some other popular apps that were built using it.

Facebook,Instagram和Airbnb都使用React Native构建了最新版本的移动应用程序。 这是使用它构建的其他一些流行应用的列表 。

Jeff Meyerson, creator of the podcast Software Engineering Daily, has talked extensively about the React Native platform. He believes it will survive and continue to capture the majority of the mobile ecosystem.

播客软件工程日报的创建者Jeff Meyerson广泛讨论了React Native平台。 他认为,这种技术将生存并继续占领大多数移动生态系统。

He has even speculated that Facebook may be creating their own mobile phone, which would be built specifically to support apps made with React Native.

他甚至推测,Facebook可能正在制造自己的手机,该手机将专门为支持使用React Native制作的应用而制造。

React Native与其他跨平台工具有何不同 (How React Native is different from other cross-platform tools)

If you’re new to React Native, it’s an open source project started by Facebook. It allows developers to build cross-platform mobile apps using JavaScript. It works very similarly to React, Facebook’s popular JavaScript library for building single page web applications.

如果您是React Native的新手,那么这是一个由Facebook启动的开源项目。 它允许开发人员使用JavaScript构建跨平台的移动应用程序。 它的工作原理与React十分相似,它是Facebook流行JavaScript库,用于构建单页Web应用程序。

I’ve always been skeptical of tools that advertise themselves as cross-platform for mobile. All too often you end up with a look, feel, and performance that doesn’t quite match the native platform.

我一直对那些宣传自己为移动平台的跨平台工具持怀疑态度。 通常,您最终会获得与本地平台不完全匹配的外观,感觉和性能。

React Native is not like other mobile app development frameworks, such as Ionic or Cordova. Those run inside of a web view, or an “HTML5 app,” or a “hybrid app.”

React Native与其他移动应用程序开发框架(例如Ionic或Cordova)不同。 它们在网络视图,“ HTML5应用”或“混合应用”中运行。

You build a high performance mobile app that is indistinguishable from one that is built using Swift/Objective-C or Java.

您构建的高性能移动应用程序与使用Swift / Objective-C或Java构建的应用程序没有区别。

That being said, it is still important to understand the intricacies and differences between platforms. The user experience for Android and iOS are fundamentally different, and you still need to build your app in a way that will feel natural on both platforms.

话虽如此,理解平台之间的复杂性和差异仍然很重要。 Android和iOS的用户体验在根本上是不同的,并且您仍然需要以在两种平台上都感觉自然的方式构建应用程序。

In addition, if there is ever a feature that you need to add that is not yet supported by the React Native library, React Native makes it easy to write your own Native Module in the corresponding language, which can then be linked to your React Native codebase.

另外,如果有需要添加的功能,而React Native库尚不支持,则React Native可以轻松地以相应的语言编写自己的Native模块 ,然后可以将其链接到React Native代码库。

如何开始 (How To Get Started)

Personally, I used this Udemy course to get started. It served as a nice refresher of react and redux, and was helpful for getting setup.

我个人是使用Udemy课程来开始学习的。 它充当了React和Redux的不错的复习,并有助于进行设置。

And recently Facebook released Create React Native App. This tool further simplifies the initial setup process.

最近,Facebook发布了Create React Native App 。 该工具进一步简化了初始设置过程。

If you’re already familiar with React, you can probably dive straight into the documentation. For only $10 however, the course is a bargain and walks you through the process of making four mobile apps as well as common components that you can reuse in future projects.

如果您已经熟悉React,可以直接阅读文档 。 但是,只需花费10美元,这门课程就可以讲价,并且引导您完成制作四个移动应用程序以及可以在将来的项目中重用的通用组件的过程。

Udemy also offers a course covering Advanced React Native Concepts, for those already familiar with the platform.

Udemy还为已经熟悉该平台的人员提供了涵盖Advanced React Native概念的课程。

在React Native中样式化 (Styling in React Native)

Styling in React Native takes some getting used to. React Native heavily uses CSS flexbox, something that I was not particularly comfortable with, even coming from a web background.

React Native的样式需要一些习惯。 React Native大量使用CSS flexbox,我对此不太满意,甚至来自网络背景。

Luckily there are already some fantastic resources to learn about flexbox:

幸运的是,已经有了一些很棒的资源来学习flexbox:

How flexbox works — explained with big, colorful, animated gifs

flexbox的工作原理-用大尺寸,彩色动画gif进行解释

React Native Layout Examples

React Native布局示例

A fun game to help you practice: Flexbox Froggy

一个有趣的游戏可以帮助您练习: Flexbox Froggy

After working with React Native for a few weeks, I now have a much better understanding of flexbox, which I can apply to my next web project.

在与React Native一起工作了几周之后,我现在对Flexbox有了更好的了解,我可以将其应用于下一个Web项目。

The current best practice is to create a styles object for each component, then apply it via inline-styles. Keep in mind that you are not actually writing CSS, so the naming of properties is a little different as well.

当前的最佳实践是为每个组件创建一个样式对象,然后通过内联样式应用它。 请记住,您实际上并不是在编写CSS,因此属性的命名也有所不同。

Another key difference is that you cannot use HTML tags in your javascript, because you are writing code to run on a phone, rather than in a browser. Instead, components are built with a set of base level components provided by the React Native library.

另一个主要区别是您不能在javascript中使用HTML标记,因为您正在编写要在手机而非浏览器上运行的代码。 相反,组件是由React Native库提供的一组基本级别的组件构建的。

It takes a little getting used to, but before you know it you’ll find yourself accidentally using a <View>&lt;/View> tag in place of a <div></div> in your next web app.

这需要一点时间来适应,但是在您不了解它之前,会发现自己不小心在下一个Web应用程序中使用<View>& lt; / View>标记place of a <div> </ div>。

To get a better feel for how all of this works, take a peek at the code for a simple button component below.

为了更好地了解所有这些工作原理,请看一下下面的简单按钮组件的代码。

Here’s the GitHub gist.

这是GitHub要点 。

Navigation is one of the few areas of React Native where there is not a consensus on a clear solution.

导航是React Native少数几个在清晰解决方案上尚未达成共识的领域之一。

React Router has become the standard library of choice for the React community, but there are a number of libraries floating around in the React Native community.

React Router已经成为React社区的标准库选择,但是React Native社区中有很多库在浮动。

Personally I used the React Native Router Flux library for my project which worked just fine. But I can see how you might run into some bigger issues on more complex projects.

我个人在我的项目中使用了React Native Router Flux库,效果很好。 但是我可以看到您可能会在更复杂的项目中遇到一些更大的问题。

Luckily, React Native has already developed a massive community. New versions of the project are released every month, so I am confident that issues like navigation will be solved over time.

幸运的是,React Native已经建立了一个庞大的社区。 该项目的新版本每个月都会发布,因此我相信随着时间的推移,导航等问题将得到解决。

开发人员体验事项 (Developer Experience Matters)

The ability to share code between Android and iOS applications is undoubtedly a draw of React Native, but it is only a small part of what makes the tool so incredible.

在Android和iOS应用程序之间共享代码的能力无疑是React Native的一大特色,但这只是使该工具如此令人难以置信的一小部分。

My favorite part of using React Native is the ability to reload immediately. I have used Android Studio in the past, and commonly had to deal with 30–60 second build times.

使用React Native时,我最喜欢的部分是能够立即重新加载。 我过去使用过Android Studio,通常不得不处理30–60秒的构建时间。

This saves time and I found it easier to get into a flow state without those pesky build times to disrupt me.

这样可以节省时间,而且我发现更容易进入流程状态,而没有那些烦人的构建时间来打扰我。

React Native makes mobile development fun again, and that alone is enough of a reason to try it out for your next project.

React Native使移动开发再次变得有趣,仅此一个理由就足以在下一个项目中进行尝试。

愿意探索 (Be Willing To Explore)

React Native is a perfect example of what can happen when we apply ideas that have proven successful in one area of software (web), to a seemingly separate area (mobile).

当我们将在某个软件领域(网络)中已被证明成功的想法应用到看似独立的领域(移动设备)时,React Native就是一个很好的例子。

As Haseeb Quereshi convincingly argued in his talk on convergence, as software engineers we should be converging on certain principles, languages and tools that can be successfully applied universally.

正如Haseeb Quereshi在关于融合的 演讲中令人信服地指出的那样,作为软件工程师,我们应该集中在可以成功普遍应用的某些原理,语言和工具上。

We should want to find what really is the optimal solution.

我们应该希望找到真正的最佳解决方案。

“Keep your identity small” — Paul Graham
“让您的身份小”-Paul Graham

Often times we become overly dogmatic within a community, which comes at the cost of gaining important insights from outside communities.

通常,我们在一个社区内变得过于教条主义,这是以从外部社区获得重要见解为代价的。

Go explore other areas.

去探索其他领域。

If you try out React Native, you’ll see just how awesome the results can be.

如果您尝试使用React Native,您将看到结果多么棒。

Thank you so much for taking the time out of your day to read my article.

非常感谢您抽出宝贵的时间阅读我的文章。

To read more of my writing on Software Development and Personal Development, visit taylormilliman.me.

要阅读有关软件开发和个人开发的更多文章,请访问taylormilliman.me 。

If you’d enjoy more detailed articles/tutorials about React Native, click the ? below and feel free to leave a comment below.

如果您喜欢有关React Native的更详细的文章/教程,请单击“?”。 请随时在下面发表评论。

翻译自: https://www.freecodecamp.org/news/after-building-my-first-react-native-app-im-now-convinced-it-s-the-future-d3c5e74f8fa8/

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

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

相关文章

delphi7 提示注册过期问题

很同情你得经过~ 因为我以前也是经常遇见这个问题~就和你说得一样~ 后来~ 我发现 下载使用的Delphi 7只能使用一个注册码&#xff0c;那就是:6AMD-PKG68E-DB8PP7-9SFE 3QH-9QW所以,你先把C:\Documents and Settings\Administrator\.borland文件夹下的两个文件删除然后用 Progra…

计算机开机引导的结果是,电脑开机显示引导媒体是怎么回事

电脑开机显示引导媒体是怎么回事分类&#xff1a;数据恢复常见问题|最后更新&#xff1a;2020年4月9日开机显示重新启动并选择适当的引导设备或插入1.如果主机上接有可移动存储介质(如光盘、移动硬盘、U盘等),将其拔掉,然后重启。2.如果仍然这样,进入主板设置中,依次检测以下几…

《操作系统真象还原》——0.23 操作系统是如何识别文件系统的

本节书摘来自异步社区《操作系统真象还原》一书中的第0章&#xff0c;第0.23节&#xff0c;作者&#xff1a;郑钢著&#xff0c;更多章节内容可以访问云栖社区“异步社区”公众号查看 0.23 操作系统是如何识别文件系统的 我们知道&#xff0c;一个硬盘上可以有很多分区&#xf…

mysql怎样修改my ini_mysql修改my.ini报错怎么办

mysql修改my.ini报错的解决办法&#xff1a;首先将mysql默认编码改成utf8mb4&#xff0c;并修改【my.ini】配置&#xff1b;然后修改变量&#xff0c;并检查是否设置成功即可。更多相关免费学习推荐&#xff1a;mysql教程(视频)mysql修改my.ini报错的解决办法&#xff1a;将mys…

golang---map类型

map 类似其它语言中的哈希表或字典&#xff0c;以key-value形式存储数据key必须是支持或!比较运算的类型&#xff0c;不可以是函数、map或sliceMap查找比线性搜索快很多&#xff0c;但比使用索引访问数据的类型慢100倍 Map使用make()创建&#xff0c;支持:这种简写方式 make([k…

易语言程序应用程序错误退出_为什么我退出Google并构建了一个向孩子们教授个人理财的应用程序

易语言程序应用程序错误退出Many of my friends thought I was crazy to leave a great position at Google to help parents and kids learn about money. Maybe they’re right.我的许多朋友都认为我为在谷歌上任职以帮助父母和孩子了解金钱而感到疯狂。 也许他们是对的。 B…

蓝叠 正在检查服务器最新,Windows update一直停留在正在检查更新

Windows update一直停留在正在检查更新&#xff0c;为什么啊&#xff1f;一、查看相关服务是否开始&#xff1a;请您根据以下步骤&#xff0c;确认windows update & BITS服务设置1. 按下WinR键输入“services.msc”(输入时不要打引号)&#xff0c;并按下回车。如果此时弹出…

spring-DataSource

spring支持的dataSource有好多&#xff0c; 如&#xff1a;自带的org.springframework.jdbc.datasource.DriverManagerDataSource ibatis、c3p0、JDBC、hibernate等等&#xff1b; 首先看第一种&#xff0c;使用自带的datasource&#xff1a; 1、项目结构 提示&#xff1a;spri…

《Nmap渗透测试指南》—第7章7.8节后台打印机服务漏洞

本节书摘来自异步社区《Nmap渗透测试指南》一书中的第7章7.8节后台打印机服务漏洞&#xff0c;作者 商广明,更多章节内容可以访问云栖社区“异步社区”公众号查看。 7.8 后台打印机服务漏洞表7.8所示为本章节所需Nmap命令表&#xff0c;表中加粗命令为本小节所需命令——后台打…

VSCODE 配置远程调试环境

以下内容为本人的著作&#xff0c;如需要转载&#xff0c;请声明原文链接 微信公众号「englyf」https://mp.weixin.qq.com/s/f1KZOlL92ojes-r2l9rlCw 我的需求是&#xff0c;在Windows桌面环境下&#xff0c;通过 VSCODE 远程调试在服务器(或者其它远程主机)的工程代码。其实就…

html动态网页效果代码_教你制作网页的第一步

Internet中有许多漂亮、美观的网页&#xff0c;要制作出这样的网页&#xff0c;必须先了解什么是网页&#xff0c;网页的基本组成是怎样的。网页又称为Web页&#xff0c;一般都包含图像、文字和超链接等元素。按表现形式的不同&#xff0c;网页可分为静态网页和动态网页。静态网…

Spring Cloud 7:Gateway

Zuul 网关 Zuul 是 Netfilx 开源的一个 API Gateway 服务器&#xff0c;本质是一个 Web Servlet 应用。其在微服务架构体系中提供动态路由、监控、弹性、安全等边缘服务。 使用 Zuul 作为网关&#xff0c;其主要原因有以下几点&#xff1a; 1、Zuul、Ribbon 以及 Consul 客户端…

nodejs开发工程师前景_Google NodeJS运行时团队的工程师Matt Loring访谈

nodejs开发工程师前景by Sameer Khoja通过Sameer Khoja Google NodeJS运行时团队的工程师Matt Loring访谈 (An Interview with Matt Loring, an engineer on Google’s NodeJS Runtime team) I had the pleasure of interviewing Matt Loring (Cornell class of 2015) who wor…

计算机EI期刊2020,2020年Ei Compendex收录的中国期刊目录( JANUARY 1, 2020 )

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼2020年Ei Compendex收录的中国期刊目录更新了&#xff0c;合计222本。本文根据最新 JANUARY 1, 2020 更新《2020年Ei Compendex收录出版物期刊目录》整理&#xff0c;需要提醒&#xff0c;目录EI是不定时更新的&#xff0c;但根据小…

mysql联合索引顺序调整_MySQL 关于联合索引的字段顺序规则讨论

联合索引的顺序&#xff0c;难道不是哪个查询条件最多用就放在前面的吗&#xff1f;比如商品有三个分类A&#xff0c;B&#xff0c;C&#xff0c;类似「界门纲目科属种」那样&#xff0c;越左类别越大。还有一个是商品来源D&#xff0c;不一定会用于查询条件中。举个例子&#…

python基础-第三篇-函数编程

基本数据类型之set set是无序不允许重复的集合set创建&#xff1a;s set&#xff08;&#xff09; 创建空集合 s {11,22,33}转换s set&#xff08;可迭代数据&#xff09;li [11,22,33,44] s set(li) print(s) #结果为{33, 11, 44, 22} 集合元素的添加与清空se {11,22,…

10个 Linux/Unix下 Bash 和 KSH shell 的作业控制实例

Linux 和 Unix 属于多任务的操作系统&#xff0c;也就是说一个系统在同一时间段内能运行多重任务(进程)。在这个新的博客系列&#xff0c;我将会列出相关的 Linux 和 Unix 作业&#xff08;job&#xff09;控制的命令&#xff0c;你可以通过这些命令在 Bash 或 Korn 还有 POSIX…

微信小程序 - 骨架屏

骨架屏 - “与其等待网络加载&#xff0c;不如提前给点暗示” 注&#xff1a;不适用复杂交互效果 演示 示例解释以及使用全在index.wxml中&#xff0c;观看需了解组件使用. 示例下载&#xff1a;微信小程序-骨架屏演示 转载于:https://www.cnblogs.com/cisum/p/10032448.html

图解机器学习 github_使用Github和Cloudflare建立网站的图解指南

图解机器学习 githubby Karan Thakkar由Karan Thakkar 使用GitHub和Cloudflare建立网站的插图指南 (An illustrated guide to setting up your website using GitHub and Cloudflare) You should read this if…如果...&#xff0c;您应该阅读此内容 You want to setup custo…

ajax拼接显示不同样式,Ajax重点整理

Ajax工作流程Ajax:在不刷新页面的情况下向服务器请求数据1.创建XMLHttpRequest对象(俗称小黄人)var xhr new XMLHttpRequest();XMLHttpRequest &#xff1a; http请求对象&#xff0c;负责实现ajax技术2.设置请求xhr.open(get, url);url:服务器地址3.发送请求xhr.send();4.注册…