zoukankan      html  css  js  c++  java
  • 初入React(一)

    React:是2013年Facebook在github上的一个开源js库,它将用户界面抽象为一个个组件,再由开发者将其组合成页面。它不是完整的MVC/MVVM框架,专注于提供清晰、简洁的view层解决方案,尽可能让用户使用原生js开发。其特点是通过生成Virtual Dom(js对象树)提升了应用性能,每当数据更新,则计算对比上次Virtual Don,对发生变化的部分做出批量更新,从而减少了实际的DOM操作。

    JSX:React固有的一种语法,允许js与html混用。

    需注意:1)所有标签必须闭合

               2)类似XML,有且只有一个根标签

               3)小写首字母对应DOM元素,大写首字母对应组件元素

               4)注释需加上{}

    组件:一组可以被公用的功能代码,具有统一的样式布局,可以通过传参展示不同的数据,例如Button组件

    React组件基本由以下三个部分组成:属性,状态,生命周期

    React组件构成方法:

    createClass、ES6 classes、无状态函数

    createClass

    cont Button =  React.createClass({

    getDefaultProps(){

    return{

    color:'red',

    text:'Confirm'

    }

    },

    render() {

    const {color, text} = this.props;

    return (

    <button className={'btn-${color}'}>

       <em>{text}</em>

    </button>

    );

    }

    )

    上述创建方式,当调用Button组件时,会被解析为React.createElement(Button)方法来创建实例

    ES6 classes

    class Button extends React.Component {

    construtor(props){

    super(props);

    }

    static defaultProps ={color:'red',text:'confirm'}

    render() {

    return(

    <button className={'btn btn-${color}'}>

    <em>{text}</em>

    </button>

       }

    }

    无状态函数(只传入props和context两个参数,无state也无生命周期)

    function Button ({color='blue',text='confirm'}){

    return (

    <button className={'btn btn-${color}'}><em>{text}</em></button>

    )

    }

  • 相关阅读:
    读 《异类》- 作者:[加拿大] 马尔科姆·格拉德威尔 有感
    docker常用操作命令
    MySQL 使用规范
    js 字符串转json对象
    Mybatis 工作原理
    JDBC连接配置
    Java 线程基础
    数组与链表
    Java 内部类
    MySQL 去重
  • 原文地址:https://www.cnblogs.com/ganmy/p/6439183.html
Copyright © 2011-2022 走看看