开发react项目步骤详解

这次给大家带来开发react项目步骤详解,开发react项目的注意事项有哪些,下面就是实战案例,一起来看一下。

1. 介绍

在开发react应用时,应该没有人用传统的方法引入react的源文件(js),然后在html编辑吧。

大家都是用webpack + es6来结合react开发前端应用。

这个时候,我们可以手动使用npm来安装各种插件,来从头到尾自己搭建环境。

比如:

npm install react react-dom --savenpm install babel babel-loader babel-core babel-preset-es2015 babel-preset-react --savenpm install babel webpack webpack-dev-server -g

登录后复制

虽然自己搭建的过程也是一个很好的学习过程,但是有时候难免遇到各种问题,特别是初学者,而且每次开发一个新应用,都要自己从头搭建,未免太繁琐。

于是,有人根据自己的经验和最佳实践,开发了脚手架,避免开发过程中的重复造轮子和做无用功,从而节省开发时间。

类似这样的脚手架,我扫了网络上比较多人用和关注的,一共发现了三个,它们分别是:

react-boilerplate

react-redux-starter-kit

create-react-app

它们的关注量都非常大,截至写这篇文章为止,在github上的star量是这样的:

开发react项目步骤详解开发react项目步骤详解开发react项目步骤详解

由此可见,使用这三个脚手架的人都相当多,最突出的是create-react-app

它是后来居上,他的开发时间都晚于前两个,但关注量却比他们还大,而且他还是facebook官方开发的。

肯定是一个优秀的产品。

下面来介绍一下它的特点。

2. 特点

它有好多好多的优点,先从安装使用说起。

2.1 简单的安装使用

create-react-app安装起来实在是太简单,只需要一条命令,不像别的脚手架,还需要去clone整个脚手架的源码,再在那基础上改。

npm install -g create-react-app

登录后复制

装完之后,生成一个新的项目,可以使用下面的命令:

create-react-app my-appcd my-app/

登录后复制

创建了my-app目录,这个时候,使用下面的命令就可以开始开发应用了。

npm start

登录后复制

默认情况下,会在开发环境下启动一个服务器,监听在3000端口,它会主动给你打开浏览器的,可以立刻就看到这个app的效果。

开发react项目步骤详解

是不是很简单?

2.2 源码结构简单清晰

在项目my-app目录中,你会发现源码非常清晰,没有多余的文件。

开发react项目步骤详解

真的很清爽,所有的源码你将放到src目录下,什么配置文件,各种乱七八糟都不用管,你只需要专注开发就好了,create-react-app都给你处理好了。

整个源码简单,又小又清爽!管理起来也方便!

如果你使用过webpack-dev-server或webpack搭建过开发环境,你就会发现,create-react-app的开发环境也有类似webpack-dev-server的–inline –hot自动刷新的功能。

什么意思呢?

就是一旦源码文件,一更新,再保存之后,浏览器会自动刷新,让你能实时查看效果。

你总要探究一下是怎么回事,难道create-react-app也用上了webpack-dev-server?

翻看了一下源码,没有找到webpack.config.js文件,如果有使用webpack就应该有这个文件,好奇怪。

看了一下node_modules目录,也没找到webpack相关的东西。

开发react项目步骤详解

先源头入手,我是用npm start命令来运行项目的。

就从package.json文件入手,它的内容是这样的:

开发react项目步骤详解

看到了这行:

"start": "react-scripts start"

登录后复制

react-scripts又是什么?

在node_modules目录中能找到它,它果然依赖了好多工具,其中就包括’webpack’。

开发react项目步骤详解

里面果然也有webpack的配置文件,也有好多脚本文件。

原来它是facebook开发的一个管理create-react-app服务的工具。

原来也是它让整个源码变得很整洁的。

因为它隐藏了没必要的文件,大多数人的配置都是差不多的。

除此之外,它还加入了eslint的功能。让你在开发过程中,更关注于代码,很不错。

开发react项目步骤详解

2.3线上编译命令

这个是create-react-app的一个大亮点,它能让你的应用骗译出在线上生产环境运行的代码,编译出来的文件很小,且文件名还带hash值,方便我们做cache,而且它还提供一个服务器,让我们在本地也能看到线上生产环境类似的效果,真的超级方便。

只需一行命令:

npm run build

登录后复制

开发react项目步骤详解

运行下面两条命令,可以查看线上生产环境的运行效果。

npm install -g pushstate-serverpushstate-server build

登录后复制

编译好的文件都会放到build目录中。

开发react项目步骤详解

2.4 api开发

在开发react应用时,难免与服务器进行数据交互,就是要跟api打交道。

这个时候,有一个问题。

api存在的服务器可能是跟react应用完全分开的,而且,开发环境跟线上环境又不太一样。

比如,开发环境中,你的react应用是跑在3000端口的,可是api服务可能跑在3001端口,这个时候,你跟api服务器交互的时候,可能会使用fetch或各种请求库,比如jquery的ajax。

这个时候可能会遇到CORS问题,毕竟端口不同,而线上环境却没有这个问题,因为你都控制线上环境的react应用和api应用,跑在同一个端口上。

按照以往思路,解决的方法可能是用环境变量,比如:

复制代码 代码如下:

const apiBaseUrl = process.env.NODE_ENV === ‘development’ ? ‘localhost:3001’ : ‘/’

但是这样搞起来,还是有些复杂,然而,create-react-app提供了一个超级简单的方法,只需要在package.json文件中,加一个配置项就可以了。

比如:

"proxy": http://localhost:3001/,

登录后复制

至于你用的是http的何种请求库,都是一样的,不用改任何代码。这个选项,只对开发环境有效,线上环境还是保持react应用和api应用同一个端口。

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

filter怎样全局使用

filter怎样全局使用

以上就是开发react项目步骤详解的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3188980.html

(0)
上一篇 2025年3月31日 23:39:23
下一篇 2025年3月31日 23:39:36

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 十大邮箱app排行榜 好用的手机邮箱app

    摘要:您是否曾经为在 php 中发送电子邮件而苦苦挣扎?139 邮箱提供了一个便捷且可靠的解决方案。如果您是 php 新手或需要一个可靠的电子邮件平台,本指南将为您提供详细的分步说明,以便轻松地从 php 代码中发送电子邮件。php小编草莓…

    2025年5月1日 编程技术
    000
  • 详解在React 组件中使用Echarts的正确姿势

    本文主要介绍了在react 组件中使用echarts的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 在完成一个需求的时候碰到一个场景需要使用柱状图。涉及到可视化,第一反应当然是Ec…

    2025年5月1日
    000
  • bootstrap和react区别

    在很多人眼里bootstrap和react都是前端框架,其实他们还是有很多区别的,bootstrap是前端页面框架,用于快速开发响应式页面,react的VisualDom(虚拟Dom);由React来管理Dom树的变化, 开发者只需使用Re…

    2025年5月1日
    000
  • bootstrap和react的区别是什么?

    区别:react是基于mvc模式的javascript框架,而bootstrap只是一个基于HTML、CSS、JAVASCRIPT开发的前端ui框架;bootstrap是基于html的UI构建工具,react是基于组件的工程构建方式。 了解…

    2025年5月1日
    000
  • 怎么用App提高你的生产力实用的技巧在这里!

    在提高生产力方面,应用软件可以成为你手中的利器。以下是一些实用的建议,帮助你通过应用软件提升工作效率: 任务和时间管理:使用Todoist或Any.do来创建任务列表和设置提醒,帮助你安排任务并确定优先级。Trello则可以用来设置看板,协…

    2025年4月30日
    000
  • 如何为成熟APP注入新的用户活力?

    当然,朋友们!让我们聊聊如何给我们心爱的成熟app注入一剂活力疫苗,让它们重焕新生,就像给《老友记》系列来个现代重启那样。 作为一款成熟的APP,它经历过上架的新鲜感,拥抱过下载榜单的巅峰,可是随着时间的推移,用户的热情好比Netflix的…

    2025年4月30日
    000
  • 社交电商赚钱的五大流程,月入十万!

    社交电商是近年来从pc端向移动端转型过程中发展出的一种新模式。正如我们所知,无论是基于平台的电商、社交电商,还是两者的结合,流量都至关重要。平台电商的主要流量来自平台分配,而社交电商的流量则完全依赖于粉丝对企业和产品的信任。本文将简要讨论社…

    2025年4月27日
    000
  • Nginx配置React项目报404怎么解决

    代码: location /demo {  root E:/;  index index.html index.htm; } 这样配置的有一个问题,只能 http://localhost/demo/来访问。  如果想访问里面的其它界面如 h…

    编程技术 2025年4月2日
    200
  • hooks怎么样,为什么vue和react都选择它!

    本篇文章我们来了解下hooks,聊聊为什么vue和react都选择它,为什么我们需要 hooks ,以及vue 和 react 自定义 hook 的异同,希望对大家有所帮助! 阅读本文,你将: 初步了解 Hooks 在 vue 与 reac…

    2025年4月1日 编程技术
    100
  • 如何覆盖组件库样式?React和Vue项目的解决方法浅析

    如何覆盖组件库样式?下面本篇文章给大家介绍一下react和react项目中优雅地覆盖组件库样式的方法,希望对大家有所帮助! 组件库的样式覆盖不掉,这应该是很多前端在工作中遇到过的问题。今天从实际案例出发分析原因,最后会给出在React和Vu…

    2025年4月1日 编程技术
    100

发表回复

登录后才能评论