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)或可能隐藏底 ...
随机推荐
- xorm-删除和软删除实例
删除数据Delete方法,参数为struct的指针并且成为查询条件.注意:当删除时,如果user中包含有bool,float64或者float32类型,有可能会使删除失败 package main i ...
- Glances - Linux上的实时系统监控工具(Centos安装)
Glances WebServer 模式 在 glances 的 WebServer 模式下,客户端只通过浏览器访问就可以获取远程服务器的运行状态. 安装成功后,使用 glances -w 命令即可 ...
- 环境变量-path
配置的是bin二进制可执行程序,用于系统查找程序的位置
- easyUi——datetimebox绑定数据失效
在做easy-ui时候,绑定数据不管在怎么写,都绑定不上去,最后发现是因为 标签的ID没有写,尴尬了,记录一下,防止后期出错. ui代码 <script type="text/java ...
- 去掉a标签点击后的虚边框
a { cursor: pointer; text-decoration: none; hide-focus: expression(this.hideFocus=true); outline: no ...
- MongoDB和Java(5):Spring Data整合MongoDB(注解配置)
最近花了一些时间学习了下MongoDB数据库,感觉还是比较全面系统的,涉及了软件安装.客户端操作.安全认证.副本集和分布式集群搭建,以及使用Spring Data连接MongoDB进行数据操作,收获很 ...
- 必须掌握的Linux用户组知识
在 Linux 系统中用户组起着重要作用.用户组提供了一种简单方法供一组用户互相共享文件.用户组也允许系统管理员更加有效地管理用户权限,因为管理员可以将权限分配给用户组而不是逐一分配给单个用户. 尽管 ...
- selenium自动化测试框架之PO设计模式
面向对象的特性:封装.继承.多态.在自动化中一样适用,Selenium自动化测试中有一个名字常常被提及PageObject(思想与面向对象的特性相同),通过PO模式可以大大提高测试用例的维护效率. 传 ...
- Vue学习之webpack中使用vue(十七)
一.包的查找规则: 1.在项目根目录中找有没有 node_modules 的文件夹: 2.在 node_modules 中根据包名,找对应的vue 文件夹: 3.在vue 文件夹中,找 一个叫做 pa ...
- PHP防止SQL注入攻击和XSS攻击
代码如下: /** * 防SQL注入和XSS攻击 * @param $arr */ function SafeFilter (&$arr) { $ra=Array('/([\x00-\x08, ...