React

1 认识React

1.1 React是Facebook内部的一个JavaScript类库,于2013年开源,可用于创建web用户界面
1.2 react是一个库,不是一个框架
1.3 react用来创建web用户界面,不做其他的事情

中文网站 http://www.reactjs.cn/
英文网站http://facebook.github.io/react/

2 React优势

2.1 传统方法

功能 对DOM进行大量的操作,注册大量的事件,完成相应的功能
缺点 需求可以使用,但是随着事件的增多,逻辑会越来越复杂,且性能不是很好

2.2 现代方法

React引用了虚拟DOM,基于React进行开发时所有的DOM结构都通过虚拟DOM进行,
每当数据发生改变,React都会从新构建整个DOM树,然后将当前整个DOM树和上一次
的DOM树进行对比,得到DOM结构的区别,然后仅仅对变化发部分进行实际的浏览器
DOM更新,由于虚拟DOM是内存数据,**性能极高**

注意! 
1 在使用了React,既不必使用jQuery了
2 虚拟DOM的概念,讲我们从频繁的DOM操作中解放出来

3 React的质疑

对于react经常会听到一些反面说法,但是优点值得分析

  • react不是MVC框架,它只专注于视图,也就是说V
  • react是一种思想,提倡"learn once,write anywhere",分web版的react.js和原声app的react natvie
  • 虚拟DOM / 组件化 / 状态机 / 单向数据流 是React的主要特性
  • 核心思想:一个应用程序在不同的时间点,当底层数据改变,react会自动化处理所有用户界面的更新

4 React入门

4.1 React是一种思想,基于这个思想,有两大实现
✔React.js 针对web开发,使用的是html,css和js进行web UI 的开发
✔React Native 针对原生app开发,包括iOS平台,Android平台

1 官网下载 http://www.reactjs.cn/react/downloads.html/

react-15.3.1.zip(压缩包)
主要文件
1 react.min.js//react的核心文件
2 react-dom.min.js//针对web页面的DOM操作
3 browser.min.js//使得浏览器中支持jsx语法(需要单独下载)

代码如下

<html>
<head>
  <script src="js/react.min.js"></script>
  <script src="js/react-dom.min.js"></script>
  <script src="js/browser.min.js"></script>
</head>
<body>
   <div id="app"></div>
  <script type="text/babel">
    //定义一个组件
    var Hello = React.createClass({
        //组件要渲染的内容
        render : function(){
              return (
                    <h2>这是react.js</h2>
        );
      }
    });
//实例化一个Hello组件对象,渲染到页面的div#app中去
ReactDOM.render(<Hello />,document.getElementById("app"));
  </script>
</body>
</html>

注意事项!
一 script标签的type属性需要变成text/babel(jsx语法解析使用)
二 创建组件的时候,使用的是react.createClass方法//构造器的方式(首字母是大写)
三 参数是一个对象,在render方法中,可以使用html标签和js的混合
四 return 返回的内容有且仅有一个根标签
五 在全部的代码中,凡是出现标签,都必须关闭
六 在ReactDOM.render方法第二个参数,必须使用DOM的原生方法获取节点
七 定义组件类的时候,类名必须是首字母大写

5 JSX(JavaScript+XML)

5.1 在react组件内部构建标签的类XML语法

  • 在定义组件类的render方法中,return部分使用
  • 在应用组件 ReactDOM.render方法中的第一个参数
  • 只要使用了jsx语法就要设置script标签的type属性值为text/babel

注意事项!
✔如果是在HTML标签,直接使用XML标签语法
✔如果是js代码,需要使用 { } 括起来

XML 语法规定
1 必须拥有唯一的根元素
2 严格区分大小写
3 所以的元素都必须关闭
4 所有的元素都必须正确嵌套
5 所有的属性都应该有属性值
6 推荐使用XMLspy工具(检查语法)

5.4 JSX优点

简单 对于熟悉XML发开发人员都能轻松红掌握JSX
更加直观,可读性强
更加具有语法化
关注分离点,JSX干净的方式确保标签与业务逻辑相分离

5.5 JSX语法

属性设置(静态,动态)
1 静态属性,HTML标签固有的属性, W3C规定

1 属性名的更改(两个)

  • class =>> className
  • for =>> htmlFor

2 行内样式

  • 在HTML中也可以使用行内样式(使用js中的对象方式来设置)
  • 使用js的对象方式来进行设置(不能使用CSS来进行设置//会报错)
    ps { { } } 使用花括号来嵌套,外面的花括号表示解析js代码,内部表示js对象
  • 注释 针对JSX语法而言,不同于js注释
    ps 注释方式 {/注释内容/}

2 动态属性,自定义属性,由用户定义
**在js中直接书写HTML代码 其实就是react.js中的jsx语法

6 组件

6.1 组件其实就是具备独立功能的一个模块(UI部件),MVC是对数据和显示相分离,组件化则是对模块之间UI功能的分离

组件化的思想(类似于搭积木)
6.2 定义组件

在react中,所有的UI都是基于组件的,最基本的组件就是HTML标签(只需要将它们组合到一起,形成一个复杂的组件)

  • 定义组件的方法:react对象中的createClass方法
  • react对象是在react.js中定义好的,可以直接使用

**定义组件
在react中,所有的UI都是基于组件的

        //定义一个CommentItem组件类
        var CommentItemComponent = React.createClass({
            getDefaultProps : function() {
                return {
                    title : '默认标题',
                    content : '默认内容'
                };
            },
            render : function(){
                return (
                    <li>
                        ![](images/avatar.png)
                        <h3>{this.props.title}</h3>
                        <p>{this.props.content}</p>
                        <ButtonComponent operate="reply" />
                    </li>
                );
            }
        });
        //定义一个CommentList组件类
        var CommentListComponent = React.createClass({
            render : function(){
                return (
                    <ul>
                        <CommentItemComponent title="自己定义的标题"/>
                        <CommentItemComponent title="标题1" content="组件!" />
                        <CommentItemComponent title="标题2" content="组件!" />
                        <CommentItemComponent title="标题3" content="组件"/>
                    </ul>
                );
            }
        });

6.3 渲染组件


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,542评论 6 504
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,822评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,912评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,449评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,500评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,370评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,193评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,074评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,505评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,722评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,841评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,569评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,168评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,783评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,918评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,962评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,781评论 2 354

推荐阅读更多精彩内容