一、条件渲染
语法:使用原生 js 的 if 或者 三元表达式 判断
 
例子:判断用户是否登录,提示:已登录、未登录 (User组件)

<script type="text/babel">
// 判断用户是否登录,提示:已登录、未登录 (User组件)
class Login extends React.Component{
constructor(props) {
super(props)
this.state = {
token : "adasd"
}
}
render(){
let {
token
} = this.state
// if(token){
// return <div><p>已登录</p></div>
// }else{
// return <div><p>未登录</p></div>
// }
return <div><p>{ token ? '已登录' : '未登录' }</p></div>
}
} ReactDOM.render(<Login />,document.querySelector('#app'))
</script>
 
二、列表 & key
语法:
forEach 	遍历数组
map		修改数组的数据,返回一个【修改过】的数组
filter  	过滤数组的数据,返回一个【新】的数组
find    	找值
findIndex   找下标
let newArr = arr.map((item,index)=> {// 遍历arr数组,将里面的值挨个赋值给item
return 数据 // return的数据会push到newArr中
})
例子:
        <script type="text/babel">
class List extends React.Component{
constructor(props){
super(props)
this.state = {
list : ['周瑜','小乔','诸葛'],
listObj : [
{id:1,content:'xxxxx1'},
{id:2,content:'xxxxx2'},
{id:3,content:'xxxxx3'},
{id:4,content:'xxxxx4'}
]
}
} render() {
let {
list,
listObj
} = this.state let listNew = list.map((item,index) => {
return <li key={index}>{ item }</li>
})
let newListObj = listObj.map((item,index) => {
return <li key={index}>id:{ item.id },content:{ item.content }</li>
}) return <div>
<p>数组</p>
<ul>{listNew}</ul>
<p>对象</p>
<ul>{newListObj}</ul>
</div>
}
} ReactDOM.render(<List />,document.querySelector('#app'))
</script>
三、表单
① 受控组件
渲染表单的React组件还控制着用户输入过程中表单发生的操作
② 非受控组件
value值为只读的0
如:input type='file'
 
③ 数据双向绑定
1. 绑定 value 值
2. change 事件触发
3. 跟新模型数据
 
例子:
<script type="text/babel">
class Test extends React.Component{
constructor(props){
super(props) // 模型数据
this.state = {
value1 : 'value1',
value2 : 2,
value3 : 'value3'
}
} render() {
let {
value1,
value2,
value3
} = this.state
return (
<div>
<p>input</p>
<input type="text" name="value1" value = {value1} onChange = { this.onChangeFn.bind(this) }/>
<p>select</p>
<select name="value2" value = {value2} onChange = { this.onChangeFn.bind(this) }>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<p>textarea</p>
<textarea name="value3" value = {value3} onChange = { this.onChangeFn.bind(this) }></textarea>
</div>
)
} // 方法
onChangeFn(e){
// 获取数据
let value = e.target.value
let name = e.target.name // 更新数据
this.setState({
[name]:value
})
}
} ReactDOM.render(<Test />,document.querySelector('#app'))
</script>
四、组件样式
语法:
① 外部引入
<link rel="stylesheet" href="路径及文件名.css">
② 行内样式
<标签名 style={ {css属性名:属性值,....,css属性名n:属性值n} }></标签名>
 
 
注:React 中添加 class 通过 className
<p className = {'aa'}>22</p>
 
五、ref标记
语法;
<标签 ref="标识"></标签名>
this.refs.标识   使用该语法获取DOM元素
 
六、组件通信
① 父传子
语法
父在调用子组件上传递数据
子通过this.props.键获取数据
 
例子
 
② 子传父
语法
父定义普通方法接受数据
子调用普通方法传递数据
 
例子
<script type="text/babel">
class Test1 extends React.Component{
constructor(props){
super(props) // 更改 this 指向
this.sendData = this.sendData.bind(this) this.state = {
msg :''
}
} render(){
return (
<div>
<p ref={'test'}>Test1</p>
{/* 传递方法 */}
<Test2 sendData = {this.sendData}/>
</div>
)
}
// 方法
// 接收数据
sendData(data){
console.log('子数据',data); // 更改数据
this.setState({
msg : data
})
}
} class Test2 extends React.Component{
constructor(props){
super(props)
this.state = {
msg:'5566'
}
}
componentDidMount(){
// 传递数据
this.props.sendData(this.state.msg)
}
render(){
return (
<div>
<p ref={'test'}>Test2</p>
</div>
)
}
} // 页面加载
ReactDOM.render(<Test1 />,document.querySelector('#app'))
</script>
③ 非父子
语法
父在调用n个子组件上传递数据(公共父)
子通过this.props.键获取数据
 
例子
<script type="text/babel">
//定义公共父类
class Test extends React.Component {
constructor(props) {
super(props) this.state = {
age:15
}
} render() {
return (
<div>
<p ref={'test'}>Test0</p>
{/* 传递数据 */}
<Test1 sendAge = {this.state.age}/>
<Test2 sendAge = {this.state.age}/>
</div>
)
} } class Test1 extends React.Component {
constructor(props) {
super(props) this.state = {
msg: ''
}
} render() {
return (
<div>
<p ref={'test1'}>Test1</p>
{/* 接受使用数据 */}
<p>{this.props.sendAge}</p>
</div>
)
}
} class Test2 extends React.Component {
constructor(props) {
super(props)
this.state = {
msg: '5566'
}
}
render() {
return (
<div>
<p ref={'test2'}>Test2</p>
{/* 接受使用数据 */}
<p>{this.props.sendAge}</p>
</div>
)
}
} // 页面加载
ReactDOM.render(<Test />, document.querySelector('#app'))
</script>
 

02-React基础语法(2)的更多相关文章

  1. php从入门到放弃系列-02.php基础语法

    php从入门到放弃系列-02.php基础语法 一.学习语法,从hello world开始 PHP(全称:PHP:Hypertext Preprocessor,即"PHP:超文本预处理器&qu ...

  2. react基础语法(五) state和props区别和使用

    props的验证: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> < ...

  3. React基础语法学习

    React主要有如下3个特点: 作为UI(Just the UI) 虚拟DOM(Virtual DOM):这是亮点 是React最重要的一个特性 放进内存 最小更新的视图,差异部分更新 diff算法 ...

  4. react 基础语法复习2- react入门以及JSX

    引入 react 以及 ReactDom import React from 'react'; import ReactDOM from 'react-dom'; 将react组件渲染到真实dom节点 ...

  5. react基础语法(一)元素渲染和基础语法规则

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  6. react 基础语法使用

    刚开始不久react,在菜鸟上及其他前辈网站上学习,下面开始我的自学笔记. 包括: 渲染元素 组件(函数方法定义.es6 class定义) 事件处理 条件渲染 列表 下面代码部分将不会再写html部分 ...

  7. react基础语法二

    这里只是对自己的学习进行一次总结,也是为了让自己以后如果长时间不使用快速记忆起来的笔记,如果想要学习,还是去官网看文档比较好一些.. 注意 下面的代码的 script标签的type类型都为 “text ...

  8. 02 Java 基础语法

    在开始 Java 基本语法之前,先说明 Java 程序的基本规范: 大小写敏感,例如 Person 和 person 是不同的 类名首字母大写,如果类名由多个单词组成,每个单词首字母都大写,例如 He ...

  9. react 基础语法复习3- 数据传递 & 数据变化(props&&state)

    react当中的数据传递是通过 props以及 state来实现的 props <Header name="kugeliu" /> Header组件当中有个name属性 ...

  10. react 基础语法复习1- 搭建开发环境

    之前有看过阮一峰老师的react教程跟着做了一遍,学习了一下.好久没看,有点忘记了,这次跟着脚手架工具系统的复习一遍.顺便学习学习 react-router 和 redux 首先,脚手架工具我使用的是 ...

随机推荐

  1. Java集合XMind与注意事项

    Java中集合使用时的几个注意事项: 1.ArrayList和HashMap都具有扩容 ArrayList初始化数组长度为10,扩容后的容量为原来的1.5倍. HashMap初始化的数组长度为16,扩 ...

  2. djiango 配置文件(setings)

    """ Django settings for ORM project. Generated by 'django-admin startproject' using D ...

  3. 通过open上网并设置开机自启与自动连接

    注意:这里所说的上网并不是FQ.只是简单的通过iptables让客户端可以访问外网.因为有些时候有这样的需求 上一篇文章为大家介绍了OpenVPN.以及它的部署工作.而这一篇主要就是讲解如何让客户端可 ...

  4. Zookeeper 部署 配置文件

    Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式. ■ 单机模式:      Zookeeper只运行在一台服务器上,适合测试环境:■ 伪集群模式:就是 ...

  5. centos7.5优化系统脚本(虚拟机下)

    #!/usr/bin/bash #安装常用软件,首先必须自行调整好网卡配置文件,保证可以上网,否则,下列优化会失败 yum -y install wget vim lrzsz bash-complet ...

  6. Github搜索技巧

    按仓库名称.说明或自述文件内容搜索 通过 in 限定符,您可以将搜索限制为仓库名称.仓库说明.自述文件内容或这些的任意组合. 如果省略此限定符,则只搜索仓库名称和说明. 限定符 示例 in:name ...

  7. Qps从300到1500的优化过程

    最近压测一项目,遇到的性能问题比较典型,过程记录下来,给大家做定位调优参考: 表象: 单接口负载测试,qps最高到300,响应时间200ms,应用cpu达到90%以上,8c机器,如下图,写到这里可能有 ...

  8. 10分钟快速搭建可用的springboot-web项目

    搭建步骤 工具准备 1. IntelliJ IDEA(开发工具,简称idea) 2. JDK1.8+ 3. MAVEN 4. mysql(数据库) 5. redis(session储存) 创建步骤 S ...

  9. 封装dropdown模块(使用到之前写好的动画组件,封装下拉菜单)

    用 showhide 改写dropdown 模块: 1.首先在 css中新增动画相关样式 /*showhide组件的样式*/ .fadeOut{ opacity:; visibility: hidde ...

  10. Edge Chromium 中如何始终允许运行 Flash 内容

    众所周知,由于 Adobe Flash 控件历史久远,积累了许多漏洞.早在2017年7月,Adobe就宣布了要在2020年底终止对 Flash 的支持.微软称其浏览器移除 Flash 插件的最后期限是 ...