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. row_number over( partition by xx)

    在原始表中 新加一个临时列 去重, 排序 比多次join性能提高很多 http://www.mysqltutorial.org/mysql-window-functions/mysql-row_num ...

  2. nodejs 模块变量 应用

    exports.allcodeandname=(function(){ var fs = require('fs'); var data = fs.readFileSync(__dirname+'/a ...

  3. vue-cli 项目结构介绍

    感谢:https://www.jianshu.com/p/7006a663fb9f 总体框架 一个vue-cli的项目结构如下,其中src文件夹是需要掌握的,所以本文也重点讲解其中的文件,至于其他相关 ...

  4. unittest(22)- p2p项目实战(8)-test_class_auto_incre

    # 8.test_class_auto_incre # 使用ddt import requests import unittest from p2p_project_7.tools.http_requ ...

  5. Redis4配置文件详解

    转载链接https://www.cnblogs.com/jeffen/p/6077661.html 守护进程模式 默认情况下 redis 不是作为守护进程运行的,如果你想让它在后台运行,你就把它改成 ...

  6. windows 右键新建html文档

    1.win+R 输入 regedit 启动注册表 2.HKEY_CLASSES_ROOT->.html 3.右键新建-项 名为:ShellNew 4.在右侧空白区右键新建字符串值FileName ...

  7. 两个不错的IT类优质号

    虽然标题已经被用烂了,但是我觉得还是用这样的方式介绍这两个不错的公众号,可能你们刚好需要,我刚好知道,仅此而已. 刚认识的一个小哥哥和一个小姐姐,他们都非常优秀,有喜欢Java和Linux的同学千万不 ...

  8. Problem 43 // Project Euler

    Sub-string divisibility The number, 1406357289, is a 0 to 9 pandigital number because it is made up ...

  9. flutter 白板工具Twitter IconFacebook Icon

    flutter 白板工具 Categories: flutter 平常桌面上都放着一些草稿纸,因为经常要整理思路.画画草图啥的.这不是电子时代嘛,就觉得在手机.pad上也可以这样写写画画,我看了有很多 ...

  10. Swift Property

    Swift中有下列几种属性 存储属性(Stored properties):存储实例的常量和变量,与类.结构体.枚举的实例相关 计算属性(Computed properties):通过某种方式计算出来 ...