react教程(一)——react优势以及组件、state、props介绍

1、react是什么?它的优势在哪?
react是在前端的单页面应用领域中,处于领导地位!它使用虚拟DOM和组件化开发的方式,重新定义了前端开发的方式。

如果说react的优势在哪?我认为是这两点!

第一点、虚拟DOM。
    虚拟DOM的方式,能够极大的提高react项目的性能问题!

    那浏览器的性能瓶颈在哪呢?react是这么认为的,大量的数据交互、事件、动画让一个项目的界面渲染变得极有压力,react的聪明之处在于,它自己只定义了两个状态,一个是渲染之前的状态,也叫虚拟DOM,一个是当前状态,通过对不同状态的对比,react仅仅需要渲染界面改变了的部分!!所以react适用于大量的数据交互的场景!!

第二点、组件化开发

    组件化开发是react的首创,它是这样认为的,一个界面的不同部分,我们可以划分为一个个小小的模块,这些小小的模块,就被称为一个个组件。

    组件树:react最底层的模块,我们称为一个根组件,一个根组件,又可以包含多个组件,组件之间形成的嵌套关系,叫做组件树!!react最终的页面模型就是由一个个的组件构成的组件树。同时,组件是可以复用,一个组件可以被复用到整个应用的任何地方,所以能够极大的提高开发效率!!

//最顶层仅仅只有一个dom元素。(根元素)
<div>
    <header></header>
    <content></content>
    <footer></footer>    
</div>

2、react的 hello world 示例
先使用script引入react相关的库。

<script src="https://cdn.bootcss.com/react/15.4.2/react.min.js"></script>
<script src="https://cdn.bootcss.com/react/15.4.2/react-dom.min.js"></script>
<script src="https://cdn.bootcss.com/babel-standalone/6.22.1/babel.min.js"></script>

再到页面中申明一个react的入口dom。

<div id='root'></div>

然后进行render操作:

ReactDOM.render(<h1>hello world!!</h1>,
document.getElementById('root'))

然后运行就会在界面中打印出来hello world!!

完整示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>react学习</title>
    <script src="https://cdn.bootcss.com/react/15.4.2/react.min.js"></script>
    <script src="https://cdn.bootcss.com/react/15.4.2/react-dom.min.js"></script>
    <script src="https://cdn.bootcss.com/babel-standalone/6.22.1/babel.min.js"></script>
</head>
<body>
    <div id="app">

    </div>
    //注意这里!!!!!type='text/babel'
    <script type="text/babel">

        ReactDOM.render(<h1>hello world!</h1>,document.getElementById('app'));
    </script>
</body>
</html>

3、上面的hello world实例说明:

第一、id为root的div是必要的,这个div相当于react这个单页面应用的入口,它所有的操作都在div中进行。

第二、ReactDOM是一个对象,它有一个render方法,这个方法有两个参数,第一个参数就是dom或者组件,第二个参数就是获取页面入口dom。作用就是把第一个参数中的内容放到这个id为root的div中去。

4、组件component!!
组件其实就是提供dom元素的。它可以用function或者class来表示。

//function的表示方式
var Hello = React.createClass({
    render: function(){
        return <div>hello world!</div>
    }
})

//注意下面换成组件了,不再是之前的dom。
ReactDOM.render(<Hello />,
document.getElementById('root'))

关于组件说明:组件必须是使用首字母大写的方式。它必须有一个render方法,render方法就是用来提供dom元素的。这也是组件的核心意义所在,无render方法的组件会报错!!

5、props
属性是用来组件通信的,在这里,仅仅只介绍props是什么,以及怎么用,更复杂的应用会在后面讲!

//这里给Hello添加一个title属性。
ReactDOM.render(<Hello title='mapbar_front' />,
document.getElementById('root'))

在界面中就是这么用:
使用this.props.title的方式进行使用。

var Hello = React.createClass({
    render: function(){
        return <div>{this.props.title} hello world!</div>
    }
})

界面就会展示出来:mapbar_front hello world!

6、state状态
相比于props,state是可以被改变的。
从作用上来说,props用于组件传值。state用于界面展示!!
在script的引入中使用state,state定义在周期函数getInitialState中。
这个函数返回一个对象,这个对象中的属性就是state。

var Hello = React.createClass({
    getInitialState: function(){ 
        return { 
            like: true
        }
    }
    render(){
        return <div>{this.state.like}</div>
    }
})

这是一个简单的使用示例。那么怎么理解state是进行页面状态管理的呢?
先不用着急,等看完事件部分,咱再回来看state。

7、事件
在react中,绑定一个事件是直接在dom中。

<div onClick={this.click}> click me!</div>

click这个函数就定义在组件中。直接看一个综合示例!!!

8、综合示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>react学习</title>
    <script src="https://cdn.bootcss.com/react/15.4.2/react.min.js"></script>
    <script src="https://cdn.bootcss.com/react/15.4.2/react-dom.min.js"></script>
    <script src="https://cdn.bootcss.com/babel-standalone/6.22.1/babel.min.js"></script>
</head>
<body>
    <div id="app">

    </div>
    <script type="text/babel">
        var Hello = React.createClass({
            getInitialState: function () {
                return {
                    like: true,
                    isShow: false
                }
            },
            click: function () {
                this.setState({
                    like: !this.state.like
                })
            },
            render () {
                return   <div>
                        <h1>hello world!{this.props.title}</h1>
                        <div>
                            {   this.state.like ? <span>I like you</span>: <span>I dislike you</span> }
                        </div>
                        <div onClick={ this.click }>tab</div>
                    </div>
            }
        })
        ReactDOM.render(<Hello title="mapbar_front" />,document.getElementById('app'));
    </script>
</body>
</html>

本篇完!!!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值