React特点:

声明式设计;建议使用JSX来描述用户界面;构建组件;单向响应的数据流;

JSX:JSX是一种JAVASCRIPT的语法扩展,元素是构成react的最小单位,JSX就是用来声明REACT中的元素的。

1.指定属性:JSX可以用引号来指定已字符串为值的属性;const element = <div tableIndex = "0"></div>

      JSX可以用大括号来定义以javascript表达式为值的属性;const element = <div>{name}</div>    小驼峰命名;

2.嵌套格式:JSX像HTML一样,闭合标签,也可以相互嵌套;

      const element = ( <div> <img src="***"/></div>)

3.使用表达式: 在JSX中可以任意使用javascript表达式,但要放在大括号里;同时在JSX代码的外面加一个小括号,防止分号自动插入的bug;不可以写语句;

     const element = ( <div>  <h1>{ hi,{format(createTime)}}</h1></div>)

     可以在if或for里面使用,将他赋值给变量,当作参数传入,也可以作为返回值;

 function gettingData(user){
if(user){
 return <h1>hello,{format(user)}</h1>
 }else{
  return <h2>hello,stranger!</h2>
 }
}

4.防注入攻击: 所有的内容在渲染之前都被转换成字符串了,这样可以有效防止XSS。

5.表示对象: Babel转译器会把JSX转换成一个名为React.createElement()的方法调用;

  以下两段类似:

  const element = (<div> <h1 className="getting">hello</h1></div>)

  React.createElement('h1', {className: 'getting'}, 'hello')

安装:

通过NPM使用react,安装淘宝镜像:

npm install -g cnpm --registry=https://registry.npm.taobao.org
npm config set registry https://registry.npm.taobao.org
使用creat-react-app快速构建React开发环境;creat-react-app自动创建的项目是基于webpack+ES6;
$ cnpm install -g create-react-app
$ create-react-app my-app
$ cd my-app/
$ npm start 入口文件:index.js
大写字母开头的都是组件;
在index.js中引入React库,使浏览器能够理解组件的语法,ReactDom库的意义在于将组件挂载到DOM节点上。
JSX一定要放在一个大的div中;
事件绑定:onClick={this.handleBtnClick},this指向这个组件;
constructor(props){
  super(props)
  this.state = {
    list: []
  }
}
如果要用到state中的值,需要在方法中用展开运算符展开内容,不直接操作state中的值;list: [...this.state.list];
在方法中直接用,不用加this,在JSX中用this.state.list;
this.setState((prevState, props) => {isCollepes: prevState.isCollepes}),setState()可以接受一个函数,这个函数接受两个参数,第一个参数表示上一个状态,第二个函数表示当前的props; 父子传参:
父传子:通过属性传参,content = {item},
在子组件用this.props.content接收;
子传父:要调用父组件传来的方法,在父组件通过创建事件句柄,并作为prop传递到子组件;
  父组件:return <TodoItem delete={this.handleDelete.bind(this)}/> handleDelete(index){};
  子组件:<div onClick={this.handleDelete.bind(this)}></div>
    handleDelete(){this.props.delete(this.props.index)} 此时,子组件将index传给了父组件,父组件中handleDelete函数中可以获取到;
父组件向子组件传事件:
  在父组件的子标签中,定义事件<Person myClick={this.handleClick.bind(this, '此值')}></Person>;
  在子组件中,<div onClick={this.props.myClick}></div> 代码优化:
在constructor中做事件中的this指向的处理,如:this.handleInput = this.handleInput.bing(this)
render函数中外层包裹的标签可以不用div空标签,换成<Fragment></Fragment>,前提是要引入{Component}; 如果要获取父组件中子标签中的内容,可以在子组件中使用this.props.children;
 

初学react的更多相关文章

  1. 初学React:JSX语法

    这是本人初学React做的学习笔记;讲的不是很深,只算是简单的进行介绍. 这是一个小系列.都是在同一个模板中搭建的,但是代码是不能正常执行的. >>第一个组件.js 'use strick ...

  2. 初学React,setState后获取到的thisstate没变,还是初始state?

    问题:(javascript)初学React,setState后获取到的thisstate没变,还是初始state?描述: getInitialState(){ return {data:[]}; } ...

  3. 重写官方TodoList,对于初学react+redux的人来说,很有好处

    虽然官网的TodoList的例子写的很详细,但是都是一步到位,就是给你一个action,好家伙,全部都写好了,给你一个reducer,所有功能也是都写好了,但是我们这些小白怎么可能一下就消化那么多,那 ...

  4. 初学 react | redux

    react | redux 一.安装 React Redux 依赖 React 0.14或更新版本 npm install --sava react-redux 你需要使用 npm 作为包管理工具,配 ...

  5. 初学React:组件的样式

    React中组件的样式有三种: <!DOCTYPE html> <html lang="en"> <head> <meta charset ...

  6. 初学React:定义一个组件

    接着聊React,今天说说如何创建一个组件类. <!DOCTYPE html> <html lang="en"> <head> <meta ...

  7. 初学 React native | 环境搭建(在模拟器上运行)

    我的电脑是windows 所以就以 windows上+Android 配置React native 环境 网上的安装教程非常多,我总结了一下,配置环境时出错原因主要是node java python ...

  8. React Native 获取组件(Component)在屏幕上的位置

    年后主客户端的需求以及老的业务迁移RN,现在疯狂的在学RN.在迁移需求的时候遇到需要获取组件在屏幕上的绝对位置.页面如下: 就需要展开的时候获取sectionHeader(默认排序)在屏幕上的具体位置 ...

  9. React 学习(一) ---- React Element /组件/JSX

    学习React的时候,你可能听到最多的就是要先学习webpack, babel,要先学会配置然后才能学react 等等,一堆的配置就把我们吓着了,根本就没有心情就学习react了.其实在最开始学习re ...

随机推荐

  1. 深入JVM内核--常用JVM配置参数

    Trace跟踪参数 -verbose:gc -XX:+printGC 可以打印GC的简要信息 [GC 4790K->374K(15872K), 0.0001606 secs] [GC 4790K ...

  2. python中的reduce函数

    python中的reduce   python中的reduce内建函数是一个二元操作函数,他用来将一个数据集合(链表,元组等)中的所有数据进行下列操作:用传给reduce中的函数 func()(必须是 ...

  3. 题解:线性规划与网络流24题 T2 太空飞行计划问题

    太空飞行计划问题 问题描述 W教授正在为国家航天中心计划一系列的太空飞行.每次太空飞行可进行一系列商业性实验而获取利润.现已确定了一个可供选择的实验集合E={E1,E2,-,Em},和进行这些实验需要 ...

  4. VBA 读取加密的Excel文件(VBA 加密Excel)

    实验成功的: ExcelApp.Workbooks.Open(文件路径,,,'密码') 这里很坑,搜了别人的博客,下面这个方法试了N次,都没用... ExcelApp.Workbooks.Open(文 ...

  5. Python爬虫-selenium的使用(2)

    使用selenium打开chrome浏览器百度进行搜索 12345678910111213141516171819202122232425 from selenium import webdriver ...

  6. Mercurial 小结

    基本操作 # 拉取 并 更新 pull pull && hg update # 撤销上一个命令(不能重复运行) hg rollback # 恢复到指定的 changeset hg st ...

  7. HBase完全分布式集群搭建

    HBase完全分布式集群搭建 hbase和hadoop一样也分为单机版,伪分布式版和完全分布式集群版,此文介绍如何搭建完全分布式集群环境搭建.hbase依赖于hadoop环境,搭建habase之前首先 ...

  8. Python---13面向对象编程

    一.类和实例 面向对象最重要的概念就是类(Class)和实例(Instance),必须牢记类是抽象的模板,比如Student类,而实例是根据类创建出来的一个个具体的“对象”,每个对象都拥有相同的方法, ...

  9. Face Recognition 人脸识别该如何测试

    猪圈子,一个有个性的订阅号 01 测量人脸识别的主要性能指标有 1.误识率(False;Accept;Rate;FAR):这是将其他人误作指定人员的概率; 2.拒识率(False;RejectRate ...

  10. jQuery学习笔记三

    使用fadeIn()js解释器会将所选元素的CSS opacity属性从0改为100,fadeTo()会动画显示所选元素,将它为改为某个特定的透明度百分比,使用fadeOut()js解释器会将所选元素 ...