关于React的入门级安装和最浅显解释

春节临近,办公室里半片空位,半片浮嚣。

想到将放假,屏幕上的代码也都变成了雀跃的小虫。

无法专心了。

终于还是强迫自己读了半篇文档,写了几坨程序。

这次记录的是关于React,最浅显的内容。

———— 我是望眼欲穿的分割线 ————

Step 1:npm init

按照向导填写各个字段,最后生成package.json文件。

容易出错的是:name的值不要和包包同名

比如我们后续需要使用npm安装几个包包:browserify react reactify ...

则name值如果写作“browserify”或“react”,此依赖会安装失败!

提示如下:

npm WARN install Refusing to install react as a dependency of itself

在OS X里一个依赖安装失败会Block其他依赖的安装,

Ubuntu里只会失败当前包的安装,不会Block其他包。

总之,name不要和包名等关键字重名就对了。

Step 2:npm install --save-dev blah blah blah

package.json文件完成后,即可安装所需的依赖了:

sudo npm install --save-dev browserify react reactify react-dom uglify-js

这里的安装不要使用全局(-g)安装。只装在当前目录里即可。

多个依赖之间是空格。

安装成功后,需要手动在package.json文件里的scripts属性中做个配置:

(假设package.json文件里的main文件是index.js)

"build": "browserify --debug index.js > myBundle.js",

"build-dist": "NODE_ENV=production browserify index.js | uglifyjs -m > myBundle.min.js",

browserify 是一个JS文件的打包工具,网上很多介绍,此不赘述。

任何包含require语句的JavaScript文件运行Browserify都会自动打包所有的依赖项。

只不过它只支持.js文件。很专一。

这个Step还没完,在package.json里还要添加一个属性:

"browserify": {
  "transform": [
    "reactify"
  ]
}

好了,这个Step完了。

Step 3:npm run build 

这个命令就创建了打包文件myBundle.js。

然后在index.html页面里引用之即可。

接下来,对index.js的每一次修改,都要run一次,页面才会有更新。

补充半句,

webpack也可以完成browserify的任务,

并且它不仅仅支持.js文件,很强大。不解释了。

Step 4:现在可以在index.js里美美的写React代码了

先require:

var React = require("react");

var ReactDOM = require(‘react-dom‘);

初次接触React代码对于用惯了jQuery的人来说不适应。

但如果写过AngularJS就容易接受了。

不仅想起了两年前写AngularJS时的痛苦,一身冷汗!

好在经过修炼,再新奇的JS写起来也不再冒冷汗了。

复述有助于自我理解,以下是对原理的通俗解释,可忽略:

jQuery对事件的监听会绑定在DOM元素上,

事件每次发生,都会对DOM有所动作。

而React通过“状态”来监听事件,每当事件发生时,状态改变,

然后在render属性里将最新状态渲染到页面上。

因此,React会通过创建UI组件,

将事件监听、状态修改、DOM结构都集成在一个组件里,

对于需要多个组件的大型WEB应用来说,这种结构更方便维护。

Step 5:React.createClass({ ... })创建UI组件

其中一个自带属性 getInitialState 要初始化各个“状态”:

注意这个函数每次创建组件时只运行一次。

getInitialState: function() {

  return {

text: "",

closed: false

  }

}

然后我们可以自定义自己的监听函数,比如:

myHandleChange: function(event) {

this.setState({

text: event.target.value,

closed: true

})

}

每次执行myHandleChange函数时都会在setState里更新状态

这里是重写了text的值和closed的值。

如何触发myHandleChange函数,就不是React的问题了,

比如将其写在input元素的onChange属性里就可以在输入时触发。

Step 6:最后将UI组件render到页面里

ReactDOM.render(<TweetBox />, document.body);

render函数接收的两个参数,一个是带尖尖括号的组件变量名,

另一个是容器,这里是document.body

但似乎官方不建议直接使用body作容器,

最好创建一个body下的容器元素。

Step 7:render函数里奇异的return

这个要单独提出来讲一下,是因我个人看它不顺眼。。。

在render函数里的return返回的是一段HTML结构,

但它的写法既不同于JS原生语法,也不遵循HTML语法,

据说这货叫作JSX什么的,Whatever。

总之,这里要注意的是4点:

a:return 后面的内容都放在小括号里

b:这段HTML结构必须包含在一个最外层元素中,不可出现两个并列的最外层元素。

c:结构里的class要写成“className”

d:引用组件内的变量时,不要带引号,例如 onChange={this.myHandleChange}

———— 我是赤裸裸的分割线 ————

以上是最浅显的内容。

但也足够支持我写一坨小程序了。

准备放假了呢。

时间: 2025-01-12 13:28:17

关于React的入门级安装和最浅显解释的相关文章

谈谈React Native环境安装中我遇到的坑

谈谈React Native环境安装 这个坑把我困了好久,真的是接近崩溃的边缘...整理出来分享给大家,希望遇到跟我一样问题的小伙伴能尽快找到答案. 首先,这是在初始化App之后,react-native run-android指令  报错如下: 这个问题困扰了好久,查阅了很多资料,使用各种解决办法,有的资料解决办法如下: 跟随着改变之后,再react-nativerun-android,运行结果如下: 以上的方法依然未能解决,反而报了其他的错误,然后我把文件中更改的地方复原. 下面是第二种方法

windows 下android react native详细安装配置过程

写在前面: 在网上搜了很多安装配置文档,感觉没有一个真的跟我安装的过程一模一样的,东拼拼西凑凑,总算是装好了,我不会告诉你,断断续续,我花了两天时间...一到黑屏报错就傻眼,幸好在react群里遇到了热心的同行,还有同事的帮助...废话就到这里了,此处只是记录我自己装载的过程,系统环境各种不一样,可能或多或少有差异. 我的电脑,windows7 64位之前已经装了eclipise,java,jdk,所以,有些安装文档上面的java的jdk和c++,我电脑上并不需要. 这里我还是都粘贴上来. 参考

React&amp;Webpack 环境安装

react的安装依赖nodejs,nodejs安装下载可从http://nodejs.org/en/下载 1.   环境安装 1.1      创建lib目录 cd E:\ReactLib 1.2      安装全局webpack包 npm install webpack -g 1.3      新建一个package.json依赖管理文件 npm init 1.4      安装webpack依赖包 npm install webpack --save-dev 2.   webpack 基本入

react创建及安装不上时的使用方法

1.创建react项目 npm install -g create-react-app //安装环境 create-react-app my-app //创建应用 应用名称my-app 最好使用正确的路径 cd my-app //移动项目 npm start //开始使用 有时候我们安装react可能会报错. 可以使用npm cache clean --force强制安装.然后根据上面的步骤再走一边就OK了. 原文地址:https://www.cnblogs.com/DJF-Dream/p/85

React使用和安装

首先通过一个简单的小例子初探react: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="https://cdn.bootcss.com/react/15.4.2/react.min.js"></script

React Native环境安装

1. 安装Homebrew ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" 2. 安装Node.js brew install node 3. 安装watchman brew install --HEAD watchman 4. 安装flow,可不安装 brew install flow 5. 创建厨师项目 npm install -g react-nat

SuSE11安装MySQL5.1.73:RPM安装方式(超简单入门级安装)

注:此安装过程只有关键步骤,仅适合入门学习使用 一. 环境准备 64位操作系统,SuSE版本11sp3.(注:kingtry是我的主机名) kingtry:~ # uname -a Linux kingtry 3.0.76-0.11-default #1 SMP Fri Jun 14 08:21:43 UTC 2013 (ccab990) x86_64 x86_64 x86_64 GNU/Linux kingtry:~ # cat /etc/SuSE-release  SUSE Linux En

【Linux】Linux下配置apache - 安装文件夹具体解释

一,apache安装路径解释 默认安装路径   /var/apache2 # /etc/apache2/ # |-- apache2.conf # | `--  ports.conf # |-- mods-enabled # | |-- *.load # | `-- *.conf # |-- conf-enabled # | `-- *.conf # `-- sites-enabled # `-- *.conf 1)apache2.conf    :apacheserver的总配置文件.包括了各

持续集成(CI)工具------Hudson/Jenkins(Continuous Integration)安装与配置具体解释

本文同意转载.但请标明出处:http://blog.csdn.net/wanghantong/article/40985653/, 版权全部 文章概述: 一. 描写叙述了持续集成工具Hudson的安装与配置 二. 描写叙述了Git .Maven环境的安装与配置 三. 描写叙述了扩展邮件通知及其配置方法 四. 描写叙述了jira的配置 一.Hudson简单介绍 Hudson是Jenkins的前身,是基于Java开发的一种持续集成工具.用于监控持续的软件版本号公布/測试项目 下载地址:http://