前言

开始了,去年(2020)说要学的React,到现在2021年的12月底了,才来实施……(年底警告!年末总结还没开始写!)

不过前端为啥要学React呢?Vue不是很好用吗?Vue确实很好用,并且MVVM模式也更容易让人接受和理解,但大概是各种社区上都说react yyds啦,react一统江山啦什么的,加上我之前学Flutter做了很多项目,对声明式UI的思想已经基本掌握了,所以就想来看看React这个被模仿者的真实面貌~

由于我后端和移动端做得比较多,当然web前端也做了不少,在这之前vue、react也都一直有在用,但属于那种最low的用法:在普通的HTML里引入vue或react的js文件然后直接单页应用的写法

因为基本没接触过npm、webpack这套基于工具链的用法,所以本文基于小白视角写成,看个乐呵就好~

折腾环境

首先折腾环境就挺烦的,日常开发环境是Windows+WSL,开发react需要nodejs,所以我打算在WSL里安装

第一个问题来了,Ubuntu apt里的node版本太低了吗,才10.x,现在官方都推荐使用16.x,请问apt里的node是活在哪个世纪?

然后我去官网下载了16.x版本的二进制包手动安装,不过配置环境变量很麻烦,而且使用sudo安装全局包的时候也报错,太麻烦了!

网上搜索了一下我决定使用nvm来管理node环境,地址:https://github.com/nvm-sh/nvm

可以看到官网的介绍,很好,就是我要的东西了

nvm allows you to quickly install and use different versions of node via the command line.

按照官网教程安装好nvm之后,只需要nvm install node一行命令就完成了node环境的安装,舒服了~

➞ nvm install node
Downloading and installing node v17.3.0...
Downloading https://nodejs.org/dist/v17.3.0/node-v17.3.0-linux-x64.tar.xz...
################################################################################################### 100.0%
Computing checksum with sha256sum
Checksums matched!
Now using node v17.3.0 (npm v8.3.0)
Creating default alias: default -> node (-> v17.3.0)

新建项目

我使用了官网文档的命令来创建app:npx create-react-app react_one,但令人沮丧的是,一直报错…

有时是这个错误

npm ERR! code ERR_SSL_DECRYPTION_FAILED_OR_BAD_RECORD_MAC
npm ERR! 139880276887488:error:1408F119:SSL routines:ssl3_get_record:decryption failed or bad record mac:../deps/openssl/openssl/ssl/record/ssl3_record.c:677:

有时是下面这个

npm ERR! Cannot read properties of undefined (reading 'isServer')

各种搜索引擎搜索无果,一开始我以为是给npm设置了国内淘宝镜像导致的,结果改回来之后错误依旧。不得不感叹,这前端的工具链也太难用了吧……

然后想起了以前遇到问题的时候请教前端带师带师给的建议是使用yarn而不是npm,所以我决定试试~

根据官网文档(https://create-react-app.dev/docs/getting-started/),使用yarn创建app的命令是:

yarn create react-app my-app

不过令人遗憾的事情又发生了,使用yarn来创建app依然报错:

TypeError: Cannot read properties of undefined (reading 'isServer')

最后一次尝试……如果不行的话我就放弃前端学习了…

这次我使用proxychains4来执行命令,因为我猜测这个报错是网络问题,然后……

Success! Created my-react at /home/da/code/frontend/1/my-react
...
We suggest that you begin by typing: cd my-react
yarn start Happy hacking!
Done in 122.59s.

欧耶!!!不容易啊,看到Success的时候,眼泪都快流下来了~

成功总在你差点就要放弃的时候到来,还好这不算晚。

开始编码!

终于可以开始了(之前的时间都花到哪里去了)

react可以使用js或者ts两种语言进行开发,作为半吊子前端且被js坑过的人来说,我肯定选Anders Hejlsberg大神的ts啦,静态类型+强类型才是最舒服的!

于是前面创建好的项目重新用ts的模板创建一遍:

yarn create react-app react_one --template typescript

正当我准备开始大干一番的时候,前端带师跟我说这react官方的create-react-app创建出来的项目不好用,推荐我使用阿里的umi框架

以下是带师原话

直接上umi吧,这个cra太折腾了

等等还得折腾路由

就一个hello world ,没有友好的引导,改点东西很难,甚至改不了

facebook:我们建议不使用装饰器

然后就不让你开启

在react和前端带师之间,我肯定选择相信带师,我就知道洋鬼子没安好心╭(╯^╰)╮

于是……

转向UmiJs

遇到一个小插曲

在看umi官方文档的时候,看到阿里搞了一个yarn的国内源,心中大喜:还有这种好东西?!

官方原话:

推荐使用 yarn 管理 npm 依赖,并使用国内源(阿里用户使用内网源)。

# 国内源$ npm i yarn tyarn -g# 后面文档里的 yarn 换成 tyarn$ tyarn -v
# 阿里内网源$ tnpm i yarn @ali/yarn -g# 后面文档里的 yarn 换成 ayarn$ ayarn -v

于是立刻安装下来

不过后面转念一想,应该请教一下有经验的带师才行(毕竟阿里在造轮子坑人这方面是有前科的)

结果前端带师的回复让我心里乱了起来

没用过

不知道是啥

怕是和cnpm一样

阿里老是造垃圾

那我还是先不用了吧,反正现在用官方的yarn也挺快的

不过刚才在安装tyarn的时候好像有什么不对劲的地方:

npm ERR! code EEXIST
npm ERR! path /home/da/.nvm/versions/node/v16.13.1/bin/yarn
npm ERR! EEXIST: file already exists
npm ERR! File exists: /home/da/.nvm/versions/node/v16.13.1/bin/yarn
npm ERR! Remove the existing file and try again, or run npm
npm ERR! with --force to overwrite files recklessly.

根据错误提示,我使用了--force参数

完了

我的yarn这下已经是阿里的形状了o(╥﹏╥)o

折腾了一天的成果,不会功亏一篑吧

怀着这样忐忑的心情,我又开始了新项目的创建……

yarn create @umijs/umi-app

跟官网说的一样,创建成功了。

然后输入yarn,开始安装依赖。再之后,yarn start启动,很好,能正常运行,后面的事情就不操心了。

后续我又根据文档测试了一下热更新添加布局、Build之类的功能,都OK~

.umirc.ts文件里添加了layout: {}配置之后呢,就出来一个侧边栏,上面赫然显示着AntDesign的logo,可以啊,真有你的,不愧是同一家的东西。

PS:热更新属实有点慢啊

刚说这话的时候,命令行弹出来一句话

热更新有点慢,试试新出的 MFSU 方案,让热更新回到 500ms 内,详见 https://github.com/umijs/umi/issues/6766

看来心里是有点B数的啊哈哈哈哈哈,那我来试试看这个什么MFSU(算了下次再写了)

参考资料

代码使我头疼之React初学习的更多相关文章

  1. clisp, scheme 和 clojure 初学习

    clisp, scheme和clojure 初学习 1 clojure "clojure绝对会成为你的编程工具箱里的终极武器" "其他语言可能只是工具,但 Clojure ...

  2. The Road to learn React书籍学习笔记(第三章)

    The Road to learn React书籍学习笔记(第三章) 代码详情 声明周期方法 通过之前的学习,可以了解到ES6 类组件中的生命周期方法 constructor() 和 render() ...

  3. (转)2019年 React 新手学习指南 – 从 React 学习线路图说开去

    原文:https://www.html.cn/archives/10111 注:本文根据 React 开发者学习线路图(2018) 结构编写了很多新手如何学习 React 的建议.2019 年有标题党 ...

  4. react基础学习和react服务端渲染框架next.js踩坑

    说明 React作为Facebook 内部开发 Instagram 的项目中,是一个用来构建用户界面的优秀 JS 库,于 2013 年 5 月开源.作为前端的三大框架之一,React的应用可以说是非常 ...

  5. React Native 学习笔记--进阶(二)--动画

    React Native 进阶(二)–动画 动画 流畅.有意义的动画对于移动应用用户体验来说是非常必要的.我们可以联合使用两个互补的系统:用于全局的布局动画LayoutAnimation,和用于创建更 ...

  6. React Native 学习-01

    React Native 学习 (学习版本 0.39) 一.环境配置 二.IDE选择 webstorm 1.webstorm配置 ①.首先是可以选择使用汉化包汉化.eu68 ②.安装插件和外部库. 由 ...

  7. 【学】React的学习之旅1

    React的学习之旅1 单标签要有斜杠代表结束 用React.createClass()方法时,赋值后的组件名称首字母一定要大写 一定要先定义组件,再用ReactDOM.render调用 组件里ren ...

  8. React Ntive 学习手记

    React使今年来比较热门的前端库,之所以说是库呢,因为React.js是应用于MVC中的V层, 它并不是一个完整的MVC框架,所以,我也不知称之为框架了. 不过这并不影响React的火热. 混合应用 ...

  9. react native 学习一(环境搭配和常见错误的解决)

    react native 学习一(环境搭配) 首页,按照http://reactnative.cn/docs/0.30/getting-started.html#content上的介绍,下载安装pyt ...

  10. React.js学习

    React.js学习之环境搭建 1 工欲善其事必先利其器:前端开发工具 1.1 WebStorm和Sublime Text Sublime Text:作为代码编辑器,Sublime Text的优点如下 ...

随机推荐

  1. ASR项目实战-项目交付历程

    本文记录,作为项目主要负责人,完整参与语音识别项目的交付历程. 2019年12月中旬 接到项目交付任务,收集基本知识,启动业务分析工作. 2020年1月 完成竞品分析的整理. 梳理合作伙伴的清单,整理 ...

  2. MinIO客户端之head

    MinIO提供了一个命令行程序mc用于协助用户完成日常的维护.管理类工作. 官方资料 mc head 查看对象的前N行内容,N默认为10,命令如下: ./mc head local1/bkt1/doc ...

  3. 编写.NET的Dockerfile文件构建镜像

    创建一个WebApi项目,并且创建一个Dockerfile空文件,添加以下代码,7.0代表的你项目使用的SDK的版本,构建的时候也需要选择好指定的镜像tag FROM mcr.microsoft.co ...

  4. Windows Server 2016 Standard RemoteApp应用发布配置举例

    RemoteApp 应用发布介绍 RemoteApp 是微软在Windows Server 2008 之后,在其系统中集成的一项服务功能,用户可以通过远程桌面访问远端服务器的桌面与程序,客户端本机在无 ...

  5. Element UI的第一个程序(标签使用)

    1:Element UI 官方文档:https://element.faas.ele.me/ 2:Element UI是什么? 网站快速成型工具 Element,一套为开发者.设计师和产品经理准备的基 ...

  6. Linux的期末冲刺

    选择 一.Linux基础 Linux目录结构 相关命令: cd, ls, pwd 详解: Linux 目录结构采用树状结构,根目录为 /.用户的帐户信息保存在 /etc/passwd 文件中,包括用户 ...

  7. 毕业季 | 程序员初入职场必备软件开发神器,华为云Astro带你开启新篇章

    摘要:5分钟写出应用,10分钟开发大屏,新手程序员必学技能之华为云Astro,快来get. 本文分享自华为云社区<毕业季 | 程序员初入职场必备软件开发神器,华为云Astro带你开启新篇章> ...

  8. 华为云应用服务网格最佳实践之从Spring Cloud 到 Istio

    摘要:在全球首届社区峰会IstioCon 2021中,华为云应用服务网格首席架构师张超盟发表了<Best practice:from Spring Cloud to Istio>主题演讲, ...

  9. 带你认识Flink容错机制的两大方面:作业执行和守护进程

    摘要:Flink 容错机制主要有作业执行的容错以及守护进程的容错两方面,前者包括 Flink runtime 的 ExecutionGraph 和Execution的容错,后者则包括 JobManag ...

  10. 互斥锁Mutex:鸿蒙轻内核中处理临界资源独占的“法官”

    摘要:本文带领大家一起剖析鸿蒙轻内核的互斥锁模块的源代码,包含互斥锁的结构体.互斥锁池初始化.互斥锁创建删除.申请释放等. 本文分享自华为云社区<鸿蒙轻内核M核源码分析系列十 互斥锁Mutex& ...