React的第二种使用方法----脚手架方式
一、React的第二种使用方法-----脚手架
1.前提:Node.js >8.10
2.下载全局脚手架工具
npm i -g create-react-app
3.运行全局脚手架工具,创建空白项目
create-react-app 项目名
4.进入空白项目,运行开发服务器
cd 项目名
npm start
5.客户端访问测试
http://127.0.0.1:3000
二、React中的数据绑定
1.内容绑定 ------ <p>{表达式}</p>
2.属性绑定 ------ <p title="{表达式}"></p>
3.指令绑定------- React中没有指令
4.事件绑定 ------ 与其他框架区别较大!
5.双向数据绑定-------与其他框架区别较大!
React中的事件句柄不同于HTML中的事件句柄(handler)
onclick --------onClick
ondbclick ------- onDoubleClick
onmouseover -------- onMouseOver
onblur -------- onBlur
.....
Vue.js中的事件绑定 Angular中的事件绑定 React中的事件绑定
<p @click="f2"></p> <p (click)="f2()"></p> <p onClick="{this.f2}"></p>
<p @click="f2()"></p>
总结:React中事件绑定需要注意:
1.事件句柄名称必须用"小驼峰命名法"
2.事件处理函数不能用引号
3.事件处理方法前必须加{ }
4.当前class内部的方法做事件处理方法,则必须加 this
5.事件处理方法名后不能加( )
面试题1:React中事件处理方法中为什么this默认指向undefined?
JSX中,事件处理方法赋值时不是函数调用,而是函数的引用赋值-------- this指向不再
指向当前组件对象!而是指向当前ES6模块中的全局this-----值为undefind
面试题2:如何解决React事件处理方法中无法使用this的问题?------用三种方法
①用匿名函数封装立即调用的函数
f2(){
console.log(this);
}
<p onClick={ ()=>{this.f2()} }></p>
②用箭头函数代替function匿名函数
f2 = ( )=>{
console.log(this);
}
<p onClick={ this.f2 }></p>
③在构造方法中固定this的指向
constructor(){
super()
this.f2 = this.f2.bind( this )
}
f2(){
}
<p onClick={ this.f2 }></p>
三、React中组件里的Model数据
React中class组件可以声明两种形式的Model数据:
①class属性------可以一次性绑定到模板,数据再变则不会再次修改视图模板.
class MyC02{
count = 3
}
②组件状态数据--------可以绑定到模板,未来Model变则View变
使用步骤:
1)创建状态数据
constructor(){
super()
this.state = { age:20 }
}
2)绑定状态数据
<p>{this.state.age}</p>
3)修改状态数据
this.setState({
age:21
})
注意:①setState()会修改虚拟DOM树
②setState()不会清空已有的状态数据,只会把新修改的数据合并到已有数据中.
③setState()是异步操作,不会立即执行-----底层会把连续的多次setState合并为一次操作,
以减少虚拟DOM/真实DOM的修改;如果希望看到修改后的值,可以使用setState({ },callback)中的回调函数.
④不推荐直接在setState中使用之前的this.state数值,使用临时变量代替
四、React中的双向数据绑定
Vue.js中的双向数据绑定 Aangular中的双向数据绑定 React中的双向数据绑定
---------------------------------------------------------------------------------------------------------------
v-model [(ngModule)] 受控组件
提示:双向数据绑定只能用于"表单元素",如input、textarea、select等
方向1:Model => View(value)
constructor(){
this.state ={ uname:'' }
}
<input value={this.state.uname}/>
至此,输入框中会呈现状态数据,但是无法再修改------受控组件
方向2:View(value) => Model
React的第二种使用方法----脚手架方式的更多相关文章
- springBoot第二种配置文件yaml书写方式及读取数据、整合myBatis和整合junit
一.yaml文件格式:key-value形式:可以表示对象 集合 1.语法:key:value 冒号后面必须跟一个空格再写value值 key1: key2: key3:value 2.属性取值:a. ...
- tornado 第二种路由方法(装饰器)
#!/usr/bin/env python # _*_coding:utf-8 _*_ import tornado.ioloop import tornado.web application = t ...
- 第二种BitBand操作的方式 - 让IDE来帮忙算地址
要使用Bitband来訪问外设,一定要得出相应的映射地址.人工计算肯定是不靠谱的,并且也没人想这么干.因此能够通过Excel,拉个列表来计算.想想,这也是一个不错的招数.可是后来想想,还是嫌麻烦,毕竟 ...
- SpringMVC实现操作的第二种方式
一: 运行效果: 点击提交之后显示效果 二: (1).web.xml <?xml version="1.0" encoding="UTF-8"?> ...
- HashMap两种遍历数据的方式
HashMap的遍历有两种方式,一种是entrySet的方式,另外一种是keySet的方式. 第一种利用entrySet的方式: Map map = new HashMap(); Iterator i ...
- CSS当中color的四种表示方法
这是我的第一篇博客,所以写的东西会比较简单. css当中,好多地方都会用到color属性,用来使html内容丰富多彩,例如:background-color:border-color: 第一种表示法使 ...
- 【转载】JavaWeb之DBUtils QueryRunner类对数据表的增、删、查(8种结果集处理方式)、改操作
一.使用QueryRunner类,实现对数据表的 insert delete update package com.shuhuadream.queryrunner; import java.sql.C ...
- 09 Python两种创建类的方式
第一种比较普遍的方式: class Work(): def __init__(self,name): self.name = name w = Work('well woker') 这样就简单创建了一 ...
- java单例的几种实现方法
java单例的几种实现方法: 方式1: public class Something { private Something() {} private static class LazyHolder ...
随机推荐
- Android程序中Acticity间传递数据
在Android开发过程中,在不同的Acitivity之间传递数据的情况是非常常见的.我花费了一点时间来总结Acitivity之间的数据传递,记录下来. 1.简单传递键值对 这种传递方式非常简单,只需 ...
- http请求返回的数字代表的含义
一些常见的状态码为: 200 - 服务器成功返回网页 404 - 请求的网页不存在 503 - 服务器超时 下面提供 HTTP 状态码的完整列表.点击链接可了解详情.您也可以访问 HTTP 状态码上的 ...
- 初入React源码(一)
导语 React是我接触的第二个框架,我最初开始接触的是vue,但是并没有深入的理解过vue,然后在工作过程中,我开始使用了React,现在已经觉得React会比vue更加实用,但是这只是个人观点,可 ...
- [mysql]linux mysql 读写分离
[mysql]linux mysql 读写分离 作者:flymaster qq:908601287 blog:http://www.cnblogs.com/flymaster500/ 1.简介 当今M ...
- 在独立的 Root 和 Home 硬盘驱动器上安装 Ubuntu
安装 Linux 系统时,可以有两种不同的方式.第一种方式是在一个超快的固态硬盘上进行安装,这样可以保证迅速开机和高速访问数据.第二种方式是在一个较慢但很强大的普通硬盘驱动器上安装,这样的硬盘转速快并 ...
- Microsoft Dynamics CRM 2015 服务器系统的性能维护,追踪, 也可以用到任务管理器哟...
Microsoft Dynamics CRM 2015 的追踪是一个很有用的function,它能为我们的CRM调试,评估 提供有价值的信息:我们可以用window的性能监控工具来了解CRM的性能状态 ...
- Github作为Maven仓库
新建发布构件项目 新建一个普通的maven项目,坐标为 创建一个类: 接着在pom文件中添加: <distributionManagement> <repository> &l ...
- 图论--网络流--费用流--POJ 2156 Minimum Cost
Description Dearboy, a goods victualer, now comes to a big problem, and he needs your help. In his s ...
- Android APP 性能测试之 GT 工具
一.介绍: GT(随身调)是 APP 的随身调测平台,它是直接运行在手机上的"集成调测环境"(IDTE, Integrated Debug Environment).利用 GT,仅 ...
- Android中限制输入框最大输入长度
通常情况下只需要在布局文件中加入maxlength这一属性即可 <EditText android:inputType="text" android:singleLine=& ...