位置: 编程技术 - 正文

快速搭建React的环境步骤详解(如何搭建react项目)

编辑:rootadmin

推荐整理分享快速搭建React的环境步骤详解(如何搭建react项目),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:搭建react开发环境,如何搭建react环境,构建react项目,如何搭建react项目,如何搭建react项目,构建react项目,如何搭建react项目,搭建react开发环境,内容如对您有帮助,希望把文章链接给更多的朋友!

前端生态这几年可谓迎来了大发展,在这个生态圈内,不接受新事物学习新技能,等于堕入魔道。

本文尝试对前端开发利器React,以及构建项目过程中涉及的技术栈进行介绍,以期开启整个构建流程上的思考。

有必要指出的是,要弄明白一件事情的原理,首先要知道它的目的是什么。

1、Nodejs & NPM

为什么要提nodejs呢?

与其说nodejs提供了服务端开发的另一种可能,不如说它彻底改变了整个前端开发的生态。nodejs平台上衍生出了强大的npm、grunt、express等,几乎重新定义了前端的工作流程和开发方式。

这里有必要来讲一讲NPM(node package manager)这个包管理器。

npm是javascript包管理器,我们可以在npm上找到、分享和使用来自无数开发者贡献的代码包,而无需自己造轮子。

使用npm,需要安装node。新的版本的nodejs已经集成了npm,安装好nodejs,通过以下命令查看所安装的版本:

在项目目录内,当在命令行执行

它会识别一个叫package.json的文件,并尝试安装该文件内配置的依赖包。

2、React

React的组建化思想使得代码重用性高,易于测试、更容易分离关注点(separation of concerns)。

React还宣称Learn Once, Write Anywhere。既可运行在客户端浏览器,又能在服务端渲染,同时React Native还使得React开发原生app成为可能。

下面我们来写一个简单的React程序,让其能够运行起来:

项目目录:

第一步:新建一个package.json文件,指定项目所需的依赖包。

这是npm包管理器的必要文件,定义了该项目的名称、版本、启动命令、生产环境依赖包(dependencies)和开发环境依赖包(devDependencies)。

第二步:新建一个index.html文件。

第三步:写一段简单的React代码。

第四步:运行。

那么如何在浏览器里运行呢?这里我们需要借助强大的webpack-dev-server来开启本地服务器。

快速搭建React的环境步骤详解(如何搭建react项目)

我们可以看到上面的package.json里面有webpack和webpack-dev-server依赖包。下面会介绍webpack。

当然我们还可以通过nodejs来建立一个本地服务器,但这里其实webpack-dev-server是一个小型的nodejs Express服务器,它使用webpack-dev-middleware中间件来服务于webpack包。

webpack.config.js文件配置如下:

这样我们在命令行通过npm install安装好依赖包以后,敲打命令

运行服务后,在浏览器中输入 entry——webpack会根据应用的依赖关系,创建一个关系表。该表的起始点便是所谓的entry point(入口点)。entry point会告诉webpack从哪入手,webpack会以该表的依赖关系作为打包依据。 output——用于配置打包后的文件放置路径。 loader——webpack把每个文件都看作组建(如.css, .html, .scss, .jpg, .png等),但是webpack只能识别JavaScript。这时候loaders便可以把这些文件转换成组建,进而被添加到依赖关系表。 plugins——因为loaders作用方式是以单一文件为基础的,所以plugins更广泛的用来对打包组建形成的集合(compilations)进行自定义操作。

这样,一个完整的模块打包体系就建立起来了。

4、ES6

ES6,即ECMAScript 6.0,是 JavaScript的下一代标准。ES6里面新增了很多语法特性,使得编写复杂的应用更加优雅自然。

ES6中引入了诸如let和const、箭头函数、解构赋值、字符串模版、Module、Class、Promise等特性,使得前后端编程语言在语法形式上的差异越来越小。

我们来看一下:

当然,并非所有浏览器都能兼容ES6全部特性,但看到这么优雅的书写方式,只能看怎么行呢?因此,这里又引出了一个神器,Babel!

5、Babel

Babel是一款JavaScript编译器。

Babel可以将ES6语法的代码转码成ES5代码,从而在浏览器环境中实现兼容。

Babel内置了对JSX的支持,所以我们才能向上面那样直接return一个JSX形式的代码片段。

具体用法不在本文过多讲述。

6、Styles引入

在上面的代码中,有以下样式引入方式:

样式文件如下:

样式文件要在项目中起作用,还需要在package.json里面添加相应的loader依赖,如css-loader, sass-loader, style-loader等,别忘了package.json里还需要node-sass依赖,然后安装即可。

webpack.config.js中相应配置如下:

再将main.js中的内容作如下更改:

最后在浏览器中可以看到:

结语

至此,一个简单的React项目便搭建起来了。

在后续的文章中,我将对本文涉及到的React技术栈做专门的讲解,不仅限于硬性技能。当然更多的是实践做法上的总结,因为如果要掌握它们的理论,细看官方文档和源码是最好不过的做法。

标签: 如何搭建react项目

本文链接地址:https://www.jiuchutong.com/biancheng/369733.html 转载请保留说明!

上一篇:two.js之实现动画效果示例(javascript动画教程)

下一篇:原生js封装添加class,删除class的实例(原生封装ajax)

  • 小规模纳税人每月不超过10万
  • 工商名称变更后多久网上可以查到记录
  • 一次性医用外科口罩哪个牌子好
  • 现代服务是可以做什么的
  • 进项税额转出要补所得税吗
  • 牵引车和挂车都要购买交强险吗
  • 支出算什么会计科目
  • 出租车定额发票真伪查询
  • 开票地址一定要写全吗
  • 外国人在中国工作签证
  • 如何根据资产负债表填写现金流量表
  • 营改增的增值税
  • 事业单位取暖费标准
  • 工业企业外购存货的入账价值一般包括增值税吗
  • 公司借款给个人利息怎么做账
  • 培训费没有发票怎么办
  • 产品成本科目包括
  • 企业接受基金投资的规定
  • 社会组织接受捐赠的资金的使用原则
  • 票据单据较多,费用报销单一张不够填怎么办?
  • 净资产收益率计算公式用期末净资产
  • 农村的生产经营是什么
  • 上市公司非限售股股票转让收入
  • 企业取得代扣代缴个税手续费分录
  • 原材料入账价值合理损耗
  • 工伤赔付是那个出钱呢
  • 专用发票验旧后还领不到发票
  • 住宿费进哪个科目
  • 年末应计提坏账准备为什么是负数
  • 开电脑店几年搞活动好吗
  • win10打开游戏老是提示
  • 长期待摊费用摊销明细表
  • 水电费无发票如何做账
  • 工资薪金专项扣除项各多少
  • 王者荣耀中李白第二次离开
  • php环境配置教程Apace
  • 公司债务转移的法律规定
  • eclipse中创建webgis项目
  • php文件怎么打开运行
  • 税款滞纳金会计处理
  • YII Framework的filter过滤器用法分析
  • php接口技术实例分析
  • 职工教育经费的计提比例是多少
  • ecshop功能
  • netbeans for php
  • 固定资产支出计入什么科目
  • 对供应商的罚款通知怎么写
  • 弥补以前年度亏损报表怎么填
  • 收到以前年度增值税退税账务处理怎么做账
  • 房地产城建税计税依据
  • 微店企业店铺和个人店铺的区别
  • PostgreSQL中关闭死锁进程的方法
  • 新会计准则折旧年限
  • 固定资产盘盈为什么计入盈余公积
  • 小规模纳税人每个月都要抄税清卡吗
  • 金税四期对企业影响
  • 建筑行业小规模纳税人和一般纳税人
  • 单位人民币卡账户的资金一律从其基本存款账户转账存入
  • 违约金 专票
  • 一般纳税人支出都要交税吗
  • 质押发票
  • 出口转内销怎么做
  • 应付利息属于什么负债
  • 公司收到赔偿款要交增值税吗
  • 电子发票一定要盖章吗
  • 小企业如何建立风险管理制度
  • sqlserver数据库显示单个用户
  • window装机必备应用
  • Windows任务栏中的活动程序间不能切换对吗
  • linux常用命令sed
  • win7怎么打开程序
  • mac os x 10.9.5
  • xp的命令提示符在哪
  • android iframe
  • 移动端web开发需要学什么
  • 国家税务总局惠州仲恺高新技术产业开发区税务局
  • 复函地税务机关对自产货物原材料向上游发函
  • 陕西社保费管理客户端初始密码
  • 无锡吴氏字辈
  • 地税局开发票流程?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设