React技术栈梳理
一、react是什么?
react是一个js框架,可以用它来编写html页面,使用react后我们可以完全抛弃html(只需要一个主index文件),而用纯js来编写页面;
二、为什么要使用react
和直接用html编写页面相比,使用react有以下几点好处:
1. 便于代码的复用
用html编写页面时,如果多个页面拥有基本相同的模块,那么需要把相关模块在各个html文件中全部复制一遍。而使用react我们只需要把这些模块写成组件,在各个页面中调用这个组件即可;
2. 提高渲染效率
当信息发生改变时,需要重新渲染页面,如果用html编写,我们需要花很多精力考虑架构问题,保证渲染效率;而react把这些问题封装了起来,编写高性能页面会变得特别容易;
3. 容易管理
当网站页面变得复杂时,页面管理将变得非常重要,我们需要花很多精力在页面架构和代码维护上,而react 让这一切变得简单;
三、react不能帮我们做什么
react的目的是让我们更好的管理和复用代码,若自己要编写react组件,那么基本的html标签的应用,css语法都是必须要掌握的;使用react后我们依然需要做以下两点:
1. 亲自编写所有要渲染的页面,虽然不用使用html,但需要用类似的 JSX语法。react只是帮我们提高了复用性;
2. 亲自写所有的css代码,页面呈现效果依然需要自己分析编写;
当然借助很多开源的react组件,可以取代一部分这些工作,不过做出的网站大都比较雷同,缺乏个性;
四、深入理解react究竟做了什么
对前端稍微有点基础的都知道,前端学习有3大块html+css+js,其中我们看到的所有web页面的显示效果只有两个因素决定 ,即html和css;只要页面发生了改变,无论是呈现的数据变了,图表变了,图片变了还是某 个颜色变了,无论这种改变是如何导致的,比如鼠标点击,声音控制或者后台数据改变。那么必然意味着 html或者css发生了改变;简而言之,页面的呈现和html+css有着一一对应的关系;而前端的主要工作,除了 编写各种页面之外,就是使用js语言根据数据来不断地更新html和css,从而使页面发生变化;
1. 原生开发如何更新页面
当js以浏览器作为宿主环境时,浏览器为js提供了DOM作为js操作文档的唯一接口,当不使用任何框架时,要更新页面,我们必须亲自调用DOM提供的API来更改文档,效率极其低下;
2. react如何更新页面
在react中每个组件都有一个state对象,它存储了当前组件需要的所有可能发生变化的数据,渲染的html页面和state中的数据是一种一一对应的关系。只要我们通过setState方法改变了state中的数据,那么html也 就跟着变化了,无需我们亲自动手修改dom;在使用react时,只要我们根据state构建了组件,接下来只需要 考虑如何更新state即可。react为更新dom提供了非常高效的算法,这里不深入展开去讲了;
五、react的基本用法
react组件的编写需要两类信息,变化的和不变的。在组件编写时要花精力去分析哪些属性在组件的生命周期 中是有可能发生变化的,哪些是不变的。不变的部分我们就可以写死在html中,针对变化的部分其信息来源 有两种 ,即组件的状态和父组件的状态;
1. 组件的状态
在编写组件时,要为组件编写一个state属性,存储了当前组件需要的数据;当需要改变状态时,调用当前组件的this.setState()方法即可,浏览器会自动重新渲染当前组件,下面是官方demo的一个例子:
class Square extends React.Component {
constructor() {
super();
this.state = {
value: null,
};
}
render() {
return (
<button className="square" onClick={() => this.setState({value: 'X'})}>
{this.state.value}
</button>
);
}
}
2. 父组件的状态
当你遇到需要同时获取多个子组件数据,或者两个组件之间需要相互通讯的情况时,把子组件的 state 数据提升至其共同的父组件当中保存。之后父组件可以通过 props 将状态数据传递到子组件当中。这样应用当中 的状态数据就能够更方便地交流共享了。(官方文档),官方示例如下:
//父组件
renderSquare(i) {
return (
<Square
value={this.state.squares[i]}
onClick={() => this.handleClick(i)}
/>
);
} //子组件
class Square extends React.Component {
render() {
return (
<button className="square" onClick={() =>this.props.onClick()}>
{this.props.value}
</button>
);
}
}
小结:
state——组件的状态属性
setState——重新设置组件的状态(这里注意,需要设置一个新的对象而不是在原有组件对象上做修改,至于原因,官方文档上说的很清楚)
props——子组件通过这个属性获得父组件的信息
六、redux
1. 为什么要使用redux
redux是一个用来管理前端数据的一个架构,只有在应用程序非常复杂,数据来源复杂,交互频繁的情况下, 应用redux才有明显的好处;比如,某个应用有上百个组件,并且组件之间信息交互频繁,如果不使用redux ,那么数据将会分散在上百个组件当中,并且当多个组件需要同一个数据时,同样的数据在每个组件中将有 一个副本,当数据改变时,维护起来会相当麻烦。这种情况下就需要考虑引入redux;
2. redux设计的三大原则
(1) 单一数据源
使用redux的程序,所有的state都存储在一个单一的数据源store内部,类似一个巨大的对象树。
(2)state是只读的
state是只读的,能改变state的唯一方式是通过触发action来修改
(3)使用纯函数执行修改
为了描述 action 如何改变 state tree , 你需要编写 reducers。reducers是一些纯函数,接口是当前state和action。只需要根据action,返回对应的state。而且必须要有返回。
3. 主要API
store=createStare(reducer)——创建store
state=store.getState()
store.dispatch(action)——触发action,这是改变state的唯一接口
store.subscribe(listener)——一旦State发生变化,就自动执行这个函数,只要把 View 的更新函数(对于 React 项目,就是组件的render方法或setState方法)放入listen,就会实现 View 的自动渲染。
4. reducer的拆分
Redux 提供了一个combineReducers方法,用于 Reducer 的拆分。你只要定义各个子 Reducer 函数,然后用这个方法,就可以将它们合成一个大的 Reducer。
七、react-redux
为了方便使用,Redux 的作者封装了一个 React 专用的库 React-Redux;React-Redux 将所有组件分成两大 类:UI 组件(presentational component)和容器组件(container component),其中UI组件,是“纯组件”,只负责呈现,所有数据通过props获取;容器组件负责数据和逻辑。可以使用装饰器模式把纯组件转化 为容器组价,这里主要用到了三个函数:
1. mapStateToProps(state,ownprops)
建立一个从(外部的)state对象到(UI 组件的)props对象的映射关系。
2. mapStateToProps(dispatch,ownProps)
用来建立store.dispatch方法到props对象的映射。
3.connect
React-Redux 提供connect方法,用于从 UI 组件生成容器组件。它需要mapStateToProps和mapStateToProps作为参数。例如:
const VisibleTodoList = connect(
mapStateToProps,
mapDispatchToProps
)(TodoList)
<Provider> 组件
当组件嵌套比较深的时候,内层组件要获得state会非常麻烦,需要借助props属性一层一层传递。Proveder组件解决了这个问题,把Provider组件放在最外层,只要在Proveder上传入store,这样所有子组件都可以拿到state了
render(
<Provider store={store}>
<App />
</Provider>,
document.getElementById('root')
)
八、react-router
一个应用程序往往不只一个页面,在多页面应用程序中我们需要在各个页面之间切换,react-route架构提供了在多个页面和组件之间进行切换的机制;react-router常用组件如下:
<BrowserRouter>
<Link>
为你的应用提供声明式的、可访问的导航链接。
--属性 to
<Route>
最基本的职责是在其 path 属性与某个 location 匹配时呈现一些 UI。
--属性 path
--属性 component
--exact完全匹配
<Switch>
只渲染命中的第一个路由
<Redirect>
直接渲染路由
--属性 to
React技术栈梳理的更多相关文章
- 重谈react优势——react技术栈回顾
react刚刚推出的时候,讲react优势搜索结果是几十页. 现在,react已经慢慢退火,该用用react技术栈的已经使用上,填过多少坑,加过多少班,血泪控诉也不下千文. 今天,再谈一遍react优 ...
- react技术栈实践(2)
本文来自网易云社区 作者:汪洋 这时候还没完,又有两个问题引出来了. 按照上面的配置,第三方库 antd 竟然也被编译了,导致样式失败. react中,一旦包裹了子组件,子组件没办法直接使用 styl ...
- react技术栈实践(1)
本文来自网易云社区 作者:汪洋 背景 最近开发一个全新AB测试平台,思考了下正好可以使用react技术开发. 实践前技术准备 首先遇到一个概念,redux.这货还真不好理解,大体的理解:Store包含 ...
- 深入React技术栈之初入React世界
1.1 react简介 react并不是完整的MVM/MVVM框架,专注于提供清晰.简洁的View层解决方案. 传统开发模式,要更新页面需要手动操作DOM元素.如图1.1所示,React在DOM上封装 ...
- 深入react技术栈解读
1. react实现virtual DOM ,如果要改变页面的内容,还是需要执行DOM操作,比原生操作DOM多了virtualDOM的操作(计算,对比等), 应该是更耗性能??? 2. react特点 ...
- 深入React技术栈之setState详解
抛出问题 class Example extends Component { contructor () { super() this.state = { value: 0, index: 0 } } ...
- React技术栈——Redux
Redux 1.Redux是什么? Redux对于JavaScript应用而言是一个可预测状态的容器.换言之,它是一个应用数据流框架,而不是传统的像underscore.js或者AngularJs ...
- H5页面开发笔记(react技术栈)
1.子组件接收父组件的参数,要在子组件的componentDidMount函数中更改当前组件的state,若写在componentWillMount函数中,则会导致初始化界面UI的时候不能得到预期的效 ...
- 一个基于React整套技术栈+Node.js的前端页面制作工具
pagemaker是一个前端页面制作工具,方便产品,运营和视觉的同学迅速开发简单的前端页面,从而可以解放前端同学的工作量.此项目创意来自网易乐得内部项目nfop中的pagemaker项目.原来项目的前 ...
随机推荐
- Linux入门(1)——Ubuntu16.04安装搜狗拼音
在网址下载搜狗deb包:http://pinyin.sogou.com/linux/ 将下载的sogoupinyin_2.1.0.0082_amd64.deb放在根目录下. 安装搜狗拼音: ltq@l ...
- GPIO工作模式
共8种工作模式,4种输入,1.输入浮空模式2.输入上拉模式 3.输入下拉模式4.模拟输入模式 4种输出模式:开漏输出.开漏复用功能.推挽输出.推挽复用输出 ps:mos管就是场效应管,三极管有的时候也 ...
- java基础-day21
第10天 IO流 今日内容介绍 u 标准输入流 & 转换流 & 打印流 u 对象操作流 u Properties集合 第1章 标准输入流 & 转换流 & 打 ...
- springMVC:HandlerInterceptor拦截器的使用
1.使用背景 Web项目中需要判断http接口用户Post上来的数据是否合法,如果不合法要另做处理,用户Post上来的数据是Json形式的,我们用了@RequestBody标记自动将json形式的提交 ...
- 怎样SQL存储过程中执行动态SQL语句
MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就 ...
- nuget.org无法解析的办法
今天想学习ef框架,就着手安装最新的ef啦.可是遇到了问题,提示 未能解析此远程名称:'nuget.org' 就去上网找资料啦,发现原来是被墙了,表示无奈. 网上的资料提示,修改hosts文件或是dn ...
- C#复数类的总结
复数是C#中没有的,不能直接调用的.但是我们可以通过封装,构造自己的复数形式.这里我自己封装了一个Complex类,也不知道写得如何.可能还有一些东西没有考虑. 不过这里包含了复数的基本晕算了了,包括 ...
- 常用Java集合类总结
此文已由作者赵计刚授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 7.1.List(允许重复元素) ArrayList: 底层数据结构:Object[] 在查询(get).遍 ...
- nginx-1.服务器是什么
服务器相信很多电脑爱好者都听过或者了解一些,一般我们很难看到真正的服务器,因为服务器一般均放置在机房重点,闲人一般均是免进的.比如我们每天浏览的网站.玩的游戏等,所有的数据均存在服务器,服务器一般都在 ...
- c# WebApi创建及客户端调用
前段时间学习WebApi的创建与调用,网上的信息千奇百怪(知识有限,看不懂啊),通过查阅资料及借鉴博友实例分析后总结一下,总结一套简单完整的WebApi创建及实例 首先创建一个WebApi服务(流程就 ...