react基本语法及组件
一、react简介
1、起源:React 起源于 Facebook 的内部项目,用来架设 Instagram 的网站,并于 2013 年 5 月开源。
2、特点:
1.声明式设计 −React采用声明式,可以轻松描述应用。 2.高效 −React通过对DOM的模拟(虚拟DOM),最大限度地减少与DOM的交互。 3.灵活 −React可以与已知的库或框架很好地配合。 4.JSX − JSX 是 JavaScript 语法的扩展。React 开发不一定使用 JSX ,但我们建议使用它。 5.组件 − 通过 React 构建组件,使得代码更加容易得到复用,能够很好的应用在大项目的开发中。 6.单向响应的数据流 − React 实现了单向响应的数据流,从而减少了重复代码,这也是它为什么比传统数据绑定更简单。
解释
a.声明式设计 和 命名式设计
1、声明式:你要做什么事情 直接告诉机器 让机器自己想办法去做 你只需要得到结果 如数组中的map遍历
var arr = [1,2,3,4,5];
arr = arr.map((item)=>{
return item+=2
})
console.log(arr) 2、命令式:你要做什么事情 按照流程书写告诉机器 让机器去实现 如使用for循环
var arr = [1,2,3,4,5];
for(var i=0;i<arr.length;i++){
arr[i]+=2;
} console.log(arr)
b.虚拟DOM ()
真实的js对象 虚拟DOM与数据相结合生成最终的DOM结构(真实)
如
createElement("
<div>ffff</div>
<p>222</p>
<p>333</p>
<p>444</p>
")
中间的标签均为虚拟DOM
二、基本语法
1、对比vue中的基本指令学习react的基本语法,
vue中包含 v-text v-html v-v-bind v-if和v-show v-for v-on v-model
import React from 'react';
import ReactDom from 'react-dom';
import App from './App'; // jsx 语法
// let Dom = <h2>这是h2标签包裹的内容,是jsx语法</h2>; // let message = 'wppp';
// v-text
// let Dom = <h3>{message} v-text</h3> // v-html
// let message = <h2>wpppp v-html</h2>
// let Dom = <div>{message}</div> // v-bind
// let message = 'wpppp v-bind';
// let Dom = <h3 title={message}>{message}</h3> // v-if v-show
// let message = 'wppp v-if v-show'
// let Dom = true?<h3 title={message} style={{display:true?'block':'none'}}>{message}</h3>:'false' // v-for
// 不加key 会报警告:Warning: Each child in an array or iterator should have a unique "key" prop. // let arr = ['www','ppp','666']
// let Dom = <ul>
// {
// arr.map((item,index)=>{
// return <li key={index}>{item}</li>
// })
// }
// </ul> // v-on
//语法与原生事件用法相同
// v-model ReactDom.render(
//
Dom,
// 调用外部引入的模块,不可直接用App 而应该用<App/>
// <App/>,
document.querySelector('#root'),
()=>{
console.log('这是第三个参数,是回调函数')
}
)
// render
// 参数1:需要渲染的组件或虚拟dom
// 参数2:将渲染好的组件放到哪个标签上面
// 参数3:回调函数
2、组件的使用
如:上述引入的App,(src 下的 index.js)
import React from 'react';
import ReactDom from 'react-dom';
import App from './App'; ReactDom.render(
<App/>,
document.querySelector('#root'),
()=>{
console.log('这是第三个参数,是回调函数')
}
)
// render
// 参数1:需要渲染的组件或虚拟dom
// 参数2:将渲染好的组件放到哪个标签上面
// 参数3:回调函数
引入的App , (src 下的 App.js),案例如下
import React,{Component,Fragment} from 'react'
import ReactDom from 'react-dom' class App extends Component{
constructor(){
super();
this.state={
firstname:'www',
lastname:'ppp'
}
}
render(){
let {firstname,lastname} = this.state;
return(
<Fragment>
<div onClick={this.handleClick1.bind(this)}>
<p>{firstname}</p>
<p>{lastname}</p>
</div>
</Fragment>
)
}
handleClick1(){
//
this.setState({
firstname:'eee',
lastname:'ddd'
})
}
}
export default App;
需注意的是:
1、React.Component 所有组建的父类
直接在引用中引用,
import React ,{Component,Fragment} from "react"; 2、在react当中所有的组件创建的时候必须首字母大写, 为了区分Element元素和组件的区别 如 App 3、render
类型:生命周期函数
作用:渲染虚拟DOM
特点:当render渲染虚拟Dom的时候会将数据和虚拟Dom结合形成真正的Dom结构,会将当前的虚拟Dom在缓存中保存一份,
当数据发生变化时会将缓存中的虚拟DOm和第二次改变的Dom进行对比。修改要改变的节点,而不是改变所有的虚拟Dom。 4、Fragment 作用当做节点标签使用 但是不会被渲染成标签 5、constructor 初始化函数 可以用来存放当前组件所需要的一些状态,为必写项!!!
且super() 为必须要写的!!!
6、react中的函数不用加() 如 <div onClick={this.handleClick1.bind(this)}> 7、react中如果需要改变this.state里面的数据 需要用this.setState方法
码字略累。。。且睡且长寿。。。。
react基本语法及组件的更多相关文章
- 我们一起来详细的了解react的语法以及组件的使用方法
jsx的介绍 React 使用 JSX 来替代常规的 JavaScript. JSX 是一个看起来很像 XML 的 JavaScript 语法扩展. jsx的优点 JSX 执行更快,因为它在编译为 J ...
- 【每天半小时学框架】——React.js的模板语法与组件概念
[重点提前说:组件化与虚拟DOM是React.js的核心理念!] 先抛出一个论题:在React.js中,JSX语法提倡将 HTML 和 CSS 全都写入到JavaScrip ...
- react系列(一)JSX语法、组件概念、生命周期介绍
JSX React中,推出了一种新的语法取名为JSX,它给了JS中写HTML标签的能力,不需要加引号.JSX的语法看起来是一种模板,然而它在编译以后,会转成JS语法,只是书写过程中的语法糖. JSX的 ...
- 【React 6/100】 React原理 | setState | JSX语法转换 | 组件更新机制
****关键字 | setState | JSX语法转换 | 组件更新机制 组件更新机制 setState() 的两个作用 修改state 更新组件 过程:父组件重新渲染时,也会重新渲染子组件,但只会 ...
- 初学React:定义一个组件
接着聊React,今天说说如何创建一个组件类. <!DOCTYPE html> <html lang="en"> <head> <meta ...
- 前端笔记之React(二)组件内部State&React实战&表单元素的受控
一.组件内部的State 1.1 state state叫状态,是每一个类式组件都有的属性,但函数式组件,没有state. state是一个对象,什么值都可以定义. 在任何类式组件的构造函数中,可以用 ...
- react基础语法(五) state和props区别和使用
props的验证: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> < ...
- 从 Vue 的视角学 React(四)—— 组件传参
组件化开发的时候,参数传递是非常关键的环节 哪些参数放在组件内部管理,哪些参数由父组件传入,哪些状态需要反馈给父组件,都需要在设计组件的时候想清楚 但实现这些交互的基础,是明白组件之间参数传递的方式, ...
- react实战系列 —— react 的第一个组件
react 的第一个组件 写了 react 有一个半月,现在又有半个月没写了,感觉对其仍旧比较陌生. 本文分两部分,首先聊一下 react 的相关概念,然后不使用任何语法糖(包括 jsx)或可能隐藏底 ...
随机推荐
- 【实战经验】--Xilinx--IPcore--MCB(DDR3)运用
1.背景与介绍 1)在导师安排的新的任务中,用到了一块2G大小的DDR3(MT41K128M16JT-107).本打算像之前用SDRAM一样自己写初始化,读写模块,但是师兄跟我说可以用Xilinx自带 ...
- C语言 - 可变参数再stm32中的应用
参考 C 可变参数 | 菜鸟教程 void func(const char* str,...) { ... } func的最后一个参数写成 ... ,表示可变参数, C语言的printf就是类似这种声 ...
- angular复习笔记1-开篇
前言 学习和使用angular已经有一段时间了.这段时间利用angular做了一个系统,算是对angular有了一个全面的认识,趁着现在有一些时间,把angular的一些知识记录一下. 安装angul ...
- dump net core windbg 安装
安装 1.下载工具windbg 地址:https://www.microsoft.com/zh-cn/p/windbg-preview/9pgjgd53tn86?SilentAuth=1&rt ...
- 带有图标的MessageBox
MessageBoxUtils类的代码如下: Ext.define('org.pine.util.MessageBoxUtils', { singleton: true, /** 普通信息提示框 */ ...
- tf常见的损失函数(LOSS)汇总
损失函数在机器学习中用于表示预测值与真实值之间的差距.一般而言,大多数机器学习模型都会通过一定的优化器来减小损失函数从而达到优化预测机器学习模型参数的目的. 哦豁,损失函数这么必要,那都存在什么损失函 ...
- 使用Docker搭建Elasticsearch集群环境
本篇文章首发于头条号单机如何搭建Elasticsearch集群?使用容器技术快速构建集群环境,欢迎关注头条号和微信公众号"大数据技术和人工智能"(微信搜索bigdata_ai_te ...
- PHP Lumen Laravel 解决validate方法自定义message无效的问题
/** * 由于 \Laravel\Lumen\Routing\ProvidesConvenienceMethods::validate 在验证不通过时, * 抛出 \Illuminate\Valid ...
- 分布式数据库中间件、产品——sharding-jdbc、mycat、drds
一般对于业务记录类随时间会不断增加的数据,当数据量增加到一定量(一般认为整型值为主的表达到千万级,字符串为主的表达到五百万)的时候,性能将遇到瓶颈,同时调整表结构也会变得非常困难.为了避免生产遇到这样 ...
- vue父组件触发子组件方法
比如应用场景是弹窗中的组件,想要点弹窗时更新该组件展示对应记录的的值 methods: { edit (record) { this.mdl = Object.assign({}, record) t ...