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)或可能隐藏底 ...
随机推荐
- day47——css介绍、语法结构、选择器、css权重
day47 今日内容 css介绍 CSS(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素,给HTML设置样式,让它更加美观. 语法结构 div{ color:gree ...
- 【转】python测试框架--doctest
转自https://my.oschina.net/lionets/blog/268542 doctest 是一个 Python 发行版自带的标准模块.有两种模式可供使用. ##1 doctest 的概 ...
- 【PYQT5快速开发】重定义边框、QSS美化皮肤主题
在用qt designer的基础上重定义边框 前言 作为一名技术工作者,偶有使用.开发工具的需求.制作工具时,既不想在界面上花太懂功夫,又想要工具模样与众不同,结果找半天找不到一键换装的功能/拍砖. ...
- php mysqli 预处理操作数据库
用到的SQL表 CREATE TABLE `student_01` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) CHARAC ...
- 关于使用K8S的技术流程
部署Gogs版本管理系统 地址:https://gogs.io/docs 部署Harbor私有仓库 地址:https://github.com/goharbor/harbor/blob/master/ ...
- ELK学习笔记之logstash将配置写在多个文件
0x00 概述 我们用Logsatsh写配置文件的时候,如果读取的文件太多,匹配的正则过多,会使配置文件动辄成百上千行代码,可能会造成阅读和修改困难.这时候,我们可以将配置文件的输入.过滤.输出分别放 ...
- x.append()增加不同维度的区别
b=np.array([[7,2],[2,4],[3,6],[7,8],[9,10]])print(b)print(type(b)) # 结果显示为nunmpy 数组a=[]for i in rang ...
- 【转载】C#中List集合使用AddRange方法将一个集合加入到指定集合末尾
C#编程开发过程中,List集合是时常使用到的集合对象,如果在List集合的操作中需要将1个List集合加入到另一个List集合的末尾,则可以使用List集合的AddRange方法来实现,AddRan ...
- Django:信号的使用
信号 Django中提供了"信号调度",用于在框架执行操作时解耦.通俗来讲,就是一些动作发生的时候,信号允许特定的发送者去提醒一些接受者. 应用:比如插入数据到数据库,插入之前写日 ...
- 解决java依赖poi导出Excel表时,没有出现下载提示的问题
转自:https://blog.csdn.net/jinchunzhao123/article/details/88626077 浏览器响应: 而且进入断点调试,所有的数据都执行了就是没有下载提示.而 ...